From 973aa054ee0fe229786415de2d46bba195f6c148 Mon Sep 17 00:00:00 2001 From: Giles Cope Date: Thu, 9 Jan 2020 20:21:07 +0000 Subject: Split out into a release build as bins were not getting generated as cargo build wasn't run --- .github/workflows/release.yaml | 131 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 131 insertions(+) create mode 100644 .github/workflows/release.yaml (limited to '.github/workflows/release.yaml') diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml new file mode 100644 index 000000000..278f5a586 --- /dev/null +++ b/.github/workflows/release.yaml @@ -0,0 +1,131 @@ +name: CI +on: + pull_request: + push: + branches: + - master + - staging + - trying + +jobs: + rust: + name: Rust + runs-on: ${{ matrix.os }} + strategy: + matrix: + os: [ubuntu-latest, windows-latest, macos-latest] + env: + RUSTFLAGS: -D warnings + CARGO_INCREMENTAL: 0 + RUN_SLOW_TESTS: 1 + RUSTUP_MAX_RETRIES: 10 + CARGO_NET_RETRY: 10 + PROFILE: release + steps: + + - name: Checkout repository + uses: actions/checkout@v1 + + # We need to disable the existing toolchain to avoid updating rust-docs + # which takes a long time. The fastest way to do this is to rename the + # existing folder, as deleting it takes about as much time as not doing + # anything and just updating rust-docs. + - name: Rename existing rust toolchain (Windows) + if: matrix.os == 'windows-latest' + run: Rename-Item C:\Users\runneradmin\.rustup\toolchains\stable-x86_64-pc-windows-msvc C:\Users\runneradmin\.rustup\toolchains\stable-x86_64-pc-windows-msvc.old + + - name: Install Rust toolchain + uses: actions-rs/toolchain@v1 + with: + toolchain: stable + profile: minimal + override: true + components: rustfmt, rust-src + + - name: Cache cargo registry + uses: actions/cache@v1 + with: + path: ~/.cargo/registry + key: ${{ runner.os }}-cargo-registry-${{ hashFiles('**/Cargo.lock') }} + + - name: Cache cargo index + uses: actions/cache@v1 + with: + path: ~/.cargo/git + key: ${{ runner.os }}-cargo-index-${{ hashFiles('**/Cargo.lock') }} + + - name: Cache cargo target dir + uses: actions/cache@v1 + with: + path: target + key: ${{ runner.os }}-cargo-build-target-${{ hashFiles('**/Cargo.lock') }} + + - name: Compile + uses: actions-rs/cargo@v1 + with: + command: build + args: --release + + - name: Test + uses: actions-rs/cargo@v1 + with: + command: test + + - name: Prepare cache + run: cargo xtask pre-cache + + - name: Prepare cache 2 + if: matrix.os == 'windows-latest' + run: Remove-Item ./target/${{ env.PROFILE }}/xtask.exe + + - name: Creat distribution dir + run: mkdir ./dist + + - name: Copy binaries (non-win) + if: matrix.os != 'windows-latest' + run: cp ./target/${{ env.PROFILE }}/ra_lsp_server* ./dist + + - name: Copy binaries (win) + if: matrix.os == 'windows-latest' + run: copy ./target/${{ env.PROFILE }}/ra_lsp_server.* ./dist + + - name: Upload artifacts + uses: actions/upload-artifact@v1 + with: + name: executables-${{ matrix.os }} + path: ./dist + + type-script: + name: TypeScript + runs-on: ubuntu-latest + env: + CXX: g++-4.9 + CC: gcc-4.9 + steps: + - name: Checkout repository + uses: actions/checkout@v1 + + - name: Install Nodejs + uses: actions/setup-node@v1 + with: + node-version: 12.x + + - run: npm ci + working-directory: ./editors/code + - run: npm run package --scripts-prepend-node-path + working-directory: ./editors/code + + - name: Create distribution directory + run: mkdir ./dist + + - name: Copy vscode extension + run: mkdir ./dist/code && cp ./editors/code/*.vsix ./dist/code/ + + - name: Copy emacs mode + run: cp -R ./editors/emacs ./dist/ + + - name: Upload artifacts + uses: actions/upload-artifact@v1 + with: + name: editors + path: ./dist -- cgit v1.2.3 From 477668fc223136064f8af48af1125380f98bfc65 Mon Sep 17 00:00:00 2001 From: Giles Cope Date: Thu, 9 Jan 2020 20:38:26 +0000 Subject: Was doing the compile twice. --- .github/workflows/release.yaml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to '.github/workflows/release.yaml') diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 278f5a586..75c2f41ae 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -1,4 +1,4 @@ -name: CI +name: CI-Release on: pull_request: push: @@ -70,6 +70,7 @@ jobs: uses: actions-rs/cargo@v1 with: command: test + args: --release - name: Prepare cache run: cargo xtask pre-cache -- cgit v1.2.3 From f1920d7b54b89432e9d8f210fdc56c82ed8e805d Mon Sep 17 00:00:00 2001 From: Giles Cope Date: Thu, 9 Jan 2020 21:11:52 +0000 Subject: Still double compiling. Try this. --- .github/workflows/release.yaml | 12 +++--------- 1 file changed, 3 insertions(+), 9 deletions(-) (limited to '.github/workflows/release.yaml') diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 75c2f41ae..3d45413e1 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -60,17 +60,11 @@ jobs: path: target key: ${{ runner.os }}-cargo-build-target-${{ hashFiles('**/Cargo.lock') }} - - name: Compile - uses: actions-rs/cargo@v1 - with: - command: build - args: --release - - - name: Test + - name: Compile and Test uses: actions-rs/cargo@v1 with: command: test - args: --release + args: --release --all-targets - name: Prepare cache run: cargo xtask pre-cache @@ -93,7 +87,7 @@ jobs: - name: Upload artifacts uses: actions/upload-artifact@v1 with: - name: executables-${{ matrix.os }} + name: server-${{ matrix.os }} path: ./dist type-script: -- cgit v1.2.3 From 42942fc66215b1bc63817e679b2fd7e18579b78f Mon Sep 17 00:00:00 2001 From: Giles Cope Date: Thu, 9 Jan 2020 22:11:25 +0000 Subject: Reducing binary size and optimising a bit more. --- .github/workflows/release.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to '.github/workflows/release.yaml') diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 3d45413e1..eff68a95c 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -78,7 +78,7 @@ jobs: - name: Copy binaries (non-win) if: matrix.os != 'windows-latest' - run: cp ./target/${{ env.PROFILE }}/ra_lsp_server* ./dist + run: cp ./target/${{ env.PROFILE }}/ra_lsp_server ./dist - name: Copy binaries (win) if: matrix.os == 'windows-latest' -- cgit v1.2.3 From 2187732fb5a4c9ae79a93b01cf82ec87f3750f9f Mon Sep 17 00:00:00 2001 From: Giles Cope Date: Thu, 9 Jan 2020 22:13:50 +0000 Subject: We only want this triggering for master. --- .github/workflows/release.yaml | 2 -- 1 file changed, 2 deletions(-) (limited to '.github/workflows/release.yaml') diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index eff68a95c..6cb27482d 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -4,8 +4,6 @@ on: push: branches: - master - - staging - - trying jobs: rust: -- cgit v1.2.3