Skip to content

Commit

Permalink
ci: actions-rust-lang/setup-rust-toolchain is better
Browse files Browse the repository at this point in the history
- It uses `rust-toolchain.toml` by default
- Has built-in support for `Swatinem/rust-cache`
  • Loading branch information
azzamsa committed Oct 11, 2023
1 parent dc2df95 commit d5d078d
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 36 deletions.
66 changes: 30 additions & 36 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,31 +10,37 @@ jobs:
- name: Checkout source code
uses: actions/checkout@v3

- name: Install rust toolchain
uses: dtolnay/rust-toolchain@stable
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
components: clippy, rustfmt

- uses: Swatinem/rust-cache@v2

- name: Install latest just release
uses: taiki-e/install-action@just

- name: Install latest dprint release
uses: taiki-e/install-action@dprint
- uses: taiki-e/install-action@just
- uses: taiki-e/install-action@dprint

- name: Check MSRV
run: |
cargo_msrv=$(sed -n 's/rust-version = "\(.*\)"/\1/p' Cargo.toml)
clippy_msrv=$(sed -n 's/msrv = "\(.*\)"/\1/p' clippy.toml)
toolchain_channel=$(sed -n 's/channel = "\(.*\)"/\1/p' rust-toolchain.toml)
echo "Cargo MSRV: $cargo_msrv"
echo "Clippy MSRV: $clippy_msrv"
echo "Toolchain Channel: $toolchain_channel"
if [ "$cargo_msrv" != "$clippy_msrv" ]; then
if [ "$cargo_msrv" = "$clippy_msrv" ] && [ "$cargo_msrv" = "toolchain_channel" ]; then
echo "MSRV match"
else
echo "MSRV do not match"
exit 1
else
echo "MSRV match"
fi
- name: Show version information
shell: bash
run: |
rustc --version
cargo --version
cargo fmt --version
- name: Ensure `fmt` has been run
run: just fmt-check

Expand All @@ -50,18 +56,10 @@ jobs:
- name: Checkout source code
uses: actions/checkout@v3

- name: Install rust toolchain (v${{ env.MIN_SUPPORTED_RUST_VERSION }})
uses: dtolnay/rust-toolchain@master
with:
toolchain: ${{ env.MIN_SUPPORTED_RUST_VERSION }}

- uses: Swatinem/rust-cache@v2
- uses: actions-rust-lang/setup-rust-toolchain@v1

- name: Install latest nextest release
uses: taiki-e/install-action@nextest

- name: Install latest just release
uses: taiki-e/install-action@just
- uses: taiki-e/install-action@nextest
- uses: taiki-e/install-action@just

- name: Prepare the environment variables
run: |
Expand All @@ -77,6 +75,12 @@ jobs:
# Check DB version
docker exec postgres_db psql -h localhost -p 5432 -U durin --version
- name: Show version information
shell: bash
run: |
rustc --version
cargo --version
- name: Run tests
env:
DATABASE_URL: postgres://durin:SpeakFriendAndEnter@localhost:5432/tin
Expand All @@ -101,20 +105,15 @@ jobs:
- name: Checkout source code
uses: actions/checkout@v3

- name: Install Rust toolchain
uses: dtolnay/rust-toolchain@stable
- uses: actions-rust-lang/setup-rust-toolchain@v1
with:
target: ${{ matrix.target }}

- name: Show version information
shell: bash
run: |
gcc --version || true
rustup -V
rustup toolchain list
rustup default
cargo -V
rustc -V
rustc --version
cargo --version
- name: Install musl-tools
if: matrix.target == 'x86_64-unknown-linux-musl'
Expand All @@ -123,10 +122,5 @@ jobs:
sudo apt-get install -y --no-install-recommends \
--allow-unauthenticated musl-tools
- name: Rust cache
uses: Swatinem/rust-cache@v2
with:
key: ${{ matrix.os }}-${{ matrix.target }}

- name: Build
run: cargo build --release --locked --target ${{ matrix.target }}
3 changes: 3 additions & 0 deletions rust-toolchain.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
[toolchain]
channel = "1.73.0"
components = ["rustfmt", "clippy"]

0 comments on commit d5d078d

Please sign in to comment.