From 47ea5d8951f4cf7eb83c6e898ec45478f354c2ea Mon Sep 17 00:00:00 2001 From: toidiu Date: Wed, 27 Mar 2024 13:06:18 -0700 Subject: [PATCH] ci: use rustup instead of actions-rs (#2168) --- .github/actions/duvet/action.yml | 13 +- .github/workflows/ci.yml | 247 +++++++++++++---------------- .github/workflows/dependencies.yml | 16 +- .github/workflows/qns.yml | 40 ++--- 4 files changed, 131 insertions(+), 185 deletions(-) diff --git a/.github/actions/duvet/action.yml b/.github/actions/duvet/action.yml index 0932814c5f..d2ecf33f46 100644 --- a/.github/actions/duvet/action.yml +++ b/.github/actions/duvet/action.yml @@ -29,11 +29,12 @@ inputs: runs: using: "composite" steps: - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - override: true + shell: bash + run: | + rustup toolchain install stable + rustup override set stable - uses: camshaft/rust-cache@v1 @@ -42,8 +43,8 @@ runs: crate: duvet - name: Generate Duvet report - run: ${{ inputs.report-script }} ${{ github.sha }} shell: bash + run: ${{ inputs.report-script }} ${{ github.sha }} - uses: aws-actions/configure-aws-credentials@v1.6.1 if: github.event_name == 'push' || github.repository == github.event.pull_request.head.repo.full_name @@ -55,6 +56,7 @@ runs: - name: Upload to S3 if: github.event_name == 'push' || github.repository == github.event.pull_request.head.repo.full_name id: s3 + shell: bash run: | if [ -n "${{ inputs.report-path }}" ]; then REPORT_PATH="${{ inputs.report-path }}" @@ -73,7 +75,6 @@ runs: URL="$PREFIX/$TARGET" echo "::set-output name=URL::$URL" - shell: bash - uses: ouzi-dev/commit-status-updater@v1.1.2 if: github.event_name == 'push' || github.repository == github.event.pull_request.head.repo.full_name diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index a2f0b02622..741188e8e1 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -74,19 +74,15 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - profile: minimal - override: true - components: rustfmt + run: | + rustup toolchain install ${{ env.RUST_NIGHTLY_TOOLCHAIN }} --profile minimal --component rustfmt + rustup override set ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - name: Run cargo fmt - uses: actions-rs/cargo@v1.0.3 - with: - command: fmt - args: --all -- --check + run: | + cargo fmt --all -- --check clippy: runs-on: ubuntu-latest @@ -103,27 +99,23 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ matrix.toolchain }} - profile: minimal - override: true - components: clippy + run: | + rustup toolchain install ${{ matrix.toolchain }} --profile minimal --component clippy + rustup override set ${{ matrix.toolchain }} - uses: camshaft/rust-cache@v1 # TODO translate json reports to in-action warnings - name: Run cargo clippy - uses: actions-rs/cargo@v1.0.3 - with: - command: clippy + run: | # deriving Eq may break API compatibility so we disable it # See https://github.com/rust-lang/rust-clippy/issues/9063 - + # # manual_clamp will panic when min > max # See https://github.com/rust-lang/rust-clippy/pull/10101 - args: --all-features --all-targets -- -A clippy::derive_partial_eq_without_eq -A clippy::manual_clamp ${{ matrix.args }} + cargo clippy --all-features --all-targets -- -A clippy::derive_partial_eq_without_eq -A clippy::manual_clamp ${{ matrix.args }} udeps: runs-on: ubuntu-latest @@ -132,12 +124,12 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - profile: minimal - override: true + run: | + rustup toolchain install ${{ env.RUST_NIGHTLY_TOOLCHAIN }} --profile minimal + rustup override set ${{ env.RUST_NIGHTLY_TOOLCHAIN }} + - uses: camshaft/rust-cache@v1 @@ -157,20 +149,17 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable + - uses: camshaft/rust-cache@v1 - name: Run cargo doc - uses: actions-rs/cargo@v1.0.3 - with: - command: doc - args: --all-features --no-deps --workspace --exclude s2n-quic-qns + run: cargo doc --all-features --no-deps --workspace --exclude s2n-quic-qns - uses: aws-actions/configure-aws-credentials@v4.0.2 if: github.event_name == 'push' || github.repository == github.event.pull_request.head.repo.full_name @@ -235,12 +224,18 @@ jobs: lfs: true submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install cross target + if: ${{ matrix.target != 'native' }} + run: | + rustup target add ${{ matrix.target }} + + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ matrix.rust }} - override: true - target: ${{ matrix.target != 'native' && matrix.target || '' }} + run: | + rustup toolchain install ${{ matrix.rust }} + rustup override set ${{ matrix.rust }} + # if not 'native', this install the toolchain for target, otherwise it's a noop + rustup toolchain install ${{ matrix.rust }} ${{ matrix.target != 'native' && format('--target {0}', matrix.target) || '' }} - name: Install cross if: ${{ matrix.target != 'native' }} @@ -262,19 +257,13 @@ jobs: run: echo ${{ matrix.env }} >> $GITHUB_ENV # Build the tests before running to improve cross compilation speed - - name: Run cargo build - uses: actions-rs/cargo@v1.0.3 - with: - command: build - args: --tests ${{ matrix.exclude }} ${{ matrix.target != 'native' && format('--target {0}', matrix.target) || '' }} ${{ matrix.args }} - use-cross: ${{ matrix.target != 'native' }} + - name: Run cargo/cross build + run: | + ${{ matrix.target != 'native' && 'cross' || 'cargo' }} build --tests ${{ matrix.exclude }} ${{ matrix.target != 'native' && format('--target {0}', matrix.target) || '' }} ${{ matrix.args }} - - name: Run cargo test - uses: actions-rs/cargo@v1.0.3 - with: - command: test - args: ${{ matrix.exclude }} ${{ matrix.target != 'native' && format('--target {0}', matrix.target) || '' }} ${{ matrix.args }} - use-cross: ${{ matrix.target != 'native' }} + - name: Run cargo/cross test + run: | + ${{ matrix.target != 'native' && 'cross' || 'cargo' }} test ${{ matrix.exclude }} ${{ matrix.target != 'native' && format('--target {0}', matrix.target) || '' }} ${{ matrix.args }} miri: # miri needs quite a bit of memory so use a larger instance @@ -289,12 +278,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - override: true - components: miri, rust-src + run: | + rustup toolchain install ${{ env.RUST_NIGHTLY_TOOLCHAIN }} --component miri,rust-src + rustup override set ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - uses: camshaft/rust-cache@v1 with: @@ -314,12 +302,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - override: true - components: rust-src + run: | + rustup toolchain install ${{ env.RUST_NIGHTLY_TOOLCHAIN }} --component rust-src + rustup override set ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - uses: camshaft/rust-cache@v1 @@ -354,23 +341,19 @@ jobs: run: | find . -name 'corpus.tar.gz' -exec dirname {} ';' | xargs -L 1 bash -c 'cd "$0" && rm -rf corpus && tar xf corpus.tar.gz' - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - override: true - components: llvm-tools-preview + run: | + rustup toolchain install ${{ env.RUST_NIGHTLY_TOOLCHAIN }} --component llvm-tools-preview + rustup override set ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - uses: camshaft/rust-cache@v1 - name: Install cargo-llvm-cov run: curl -LsSf https://github.com/taiki-e/cargo-llvm-cov/releases/latest/download/cargo-llvm-cov-x86_64-unknown-linux-gnu.tar.gz | tar xzf - -C ~/.cargo/bin - - name: Run cargo test - uses: actions-rs/cargo@v1.0.3 - with: - command: llvm-cov - args: --html --no-fail-fast --workspace --exclude s2n-quic-qns --exclude s2n-quic-events --all-features + - name: Run cargo llvm-cov + run: cargo llvm-cov --html --no-fail-fast --workspace --exclude s2n-quic-qns --exclude s2n-quic-events --all-features - uses: aws-actions/configure-aws-credentials@v4.0.2 if: github.event_name == 'push' || github.repository == github.event.pull_request.head.repo.full_name @@ -411,18 +394,15 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ needs.env.outputs.msrv }} - profile: minimal - override: true + run: | + rustup toolchain install ${{ needs.env.outputs.msrv }} --profile minimal + rustup override set ${{ needs.env.outputs.msrv }} - - name: build - uses: actions-rs/cargo@v1.0.3 - with: - command: build - args: --manifest-path ${{ matrix.crate }} + + - name: Run cargo build + run: cargo build --manifest-path ${{ matrix.crate }} examples: needs: env @@ -438,17 +418,16 @@ jobs: submodules: true # nightly features are used for formatting - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust nightly toolchain id: nightly-toolchain - with: - toolchain: nightly - components: rustfmt + run: | + rustup toolchain install nightly --component rustfmt - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust stable toolchain id: stable-toolchain - with: - toolchain: stable - override: true + run: | + rustup toolchain install stable + rustup override set stable - uses: camshaft/rust-cache@v1 with: @@ -477,12 +456,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable - uses: camshaft/rust-cache@v1 @@ -520,20 +498,16 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable - uses: camshaft/rust-cache@v1 - name: Run cargo build - uses: actions-rs/cargo@v1.0.3 - with: - command: build - args: --bin s2n-quic-sim --release + run: cargo build --bin s2n-quic-sim --release - name: Run simulations run: | @@ -579,13 +553,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - profile: minimal - override: true - components: rustfmt + run: | + rustup toolchain install ${{ env.RUST_NIGHTLY_TOOLCHAIN }} --profile minimal --component rustfmt + rustup override set ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - uses: camshaft/rust-cache@v1 @@ -606,12 +578,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable - name: Install cargo-insta uses: camshaft/install@v1 @@ -638,12 +609,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - profile: minimal - override: true + run: | + rustup toolchain install ${{ env.RUST_NIGHTLY_TOOLCHAIN }} --profile minimal + rustup override set ${{ env.RUST_NIGHTLY_TOOLCHAIN }} - name: Run cargo build run: | @@ -680,12 +650,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable - uses: camshaft/install@v1 with: @@ -719,12 +688,11 @@ jobs: steps: - uses: actions/checkout@v4 - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable - uses: camshaft/rust-cache@v1 @@ -781,12 +749,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable - uses: camshaft/rust-cache@v1 with: @@ -805,13 +772,11 @@ jobs: with: lfs: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true - components: clippy,rustfmt + run: | + rustup toolchain install stable --profile minimal --component clippy,rustfmt + rustup override set stable - uses: camshaft/install@v1 with: diff --git a/.github/workflows/dependencies.yml b/.github/workflows/dependencies.yml index 0f33ee7fe1..102d82d734 100644 --- a/.github/workflows/dependencies.yml +++ b/.github/workflows/dependencies.yml @@ -28,21 +28,7 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 - with: - submodules: true - - - uses: actions-rs/toolchain@v1.0.7 - id: toolchain - with: - toolchain: stable - profile: minimal - override: true - - - uses: camshaft/install@v1 - with: - crate: cargo-audit - - - uses: actions-rs/audit-check@v1 + - uses: rustsec/audit-check@v1.4.1 with: token: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/qns.yml b/.github/workflows/qns.yml index 08429fb653..975050ec76 100644 --- a/.github/workflows/qns.yml +++ b/.github/workflows/qns.yml @@ -81,22 +81,18 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable - uses: camshaft/rust-cache@v1 with: key: ${{ matrix.mode }}-${{ env.RUSTFLAGS }} - name: Run cargo build - uses: actions-rs/cargo@v1.0.3 - with: - command: build - args: --bin s2n-quic-qns ${{ matrix.mode == 'release' && '--release' || '' }} + run: cargo build --bin s2n-quic-qns ${{ matrix.mode == 'release' && '--release' || '' }} - name: Prepare artifact run: | @@ -345,11 +341,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - override: true + run: | + rustup toolchain install stable + rustup override set stable - uses: camshaft/rust-cache@v1 @@ -474,12 +470,11 @@ jobs: with: submodules: true - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable - name: Install perf run: | @@ -591,12 +586,11 @@ jobs: steps: - uses: actions/checkout@v4 - - uses: actions-rs/toolchain@v1.0.7 + - name: Install rust toolchain id: toolchain - with: - toolchain: stable - profile: minimal - override: true + run: | + rustup toolchain install stable --profile minimal + rustup override set stable - uses: actions/download-artifact@v4 with: