1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
name: CI
on:
push:
branches:
pull_request:
branches:
schedule:
- cron: '13 3 * * 1' # one week
env:
CARGO_TERM_COLOR: always
RUST_BACKTRACE: 1
jobs:
fmt-clippy:
name: fmt + clippy
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@stable
with:
components: rustfmt, clippy
- run: cargo fmt --all -- --check
- run: cargo clippy --all-targets --all-features -- -D warnings
# Main test matrix
test:
name: test ${{ matrix.rust }} on ${{ matrix.os }}
runs-on: ${{ matrix.os }}
strategy:
fail-fast: false
matrix:
rust:
os:
exclude:
# Reduce jobs: only stable on macOS/Windows
- os: macos-latest
rust: beta
- os: macos-latest
rust: nightly
- os: windows-latest
rust: beta
- os: windows-latest
rust: nightly
steps:
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@master
with:
toolchain: ${{ matrix.rust }}
- uses: Swatinem/rust-cache@v2
- run: cargo build --verbose
- run: cargo test --all-features --verbose
- run: cargo doc --no-deps --all-features
env:
RUSTDOCFLAGS: -D warnings
# TODO: enable deny
# Full cargo-deny check (licenses, advisories, bans, sources, duplicates)
#deny:
#name: deny
#runs-on: ubuntu-latest
#steps:
#- uses: actions/checkout@v4
#- uses: dtolnay/rust-toolchain@stable
#- uses: EmbarkStudios/cargo-deny-action@v2 # runs licenses, advisories, bans, sources, duplicates
# Audit to check for security vulnerabilities
# TODO: enable audit
#audit:
#name: audit
#runs-on: ubuntu-latest
#steps:
#- uses: actions/checkout@v4
#- uses: dtolnay/rust-toolchain@stable
#- run: cargo install cargo-audit
#- run: cargo audit