release: 0.20.0 #3517
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# The "Normal" CI for tests and linters and whatnot | |
name: Rust CI | |
# Ci should be run on... | |
on: | |
# Every pull request (will need approval for new contributors) | |
pull_request: | |
# Every push to... | |
push: | |
branches: | |
# The main branch | |
- main | |
# And once a week? | |
# This can catch things like "rust updated and actually regressed something" | |
schedule: | |
- cron: "11 7 * * 1,4" | |
# We want all these checks to fail if they spit out warnings | |
env: | |
RUSTFLAGS: -Dwarnings | |
jobs: | |
# Test and fmt the npm pkg | |
npm: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: 20 | |
- name: npm fmt | |
working-directory: cargo-dist/templates/installer/npm | |
run: npm ci && npm run fmt:check | |
# Check that rustfmt is a no-op | |
fmt: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: stable | |
components: rustfmt | |
- run: cargo fmt --all -- --check | |
# Check that clippy is appeased | |
clippy: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: stable | |
components: clippy | |
- uses: swatinem/rust-cache@v2 | |
- uses: actions-rs/clippy-check@v1 | |
env: | |
PWD: ${{ env.GITHUB_WORKSPACE }} | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
args: --workspace --tests --examples | |
# Make sure the docs build without warnings | |
docs: | |
runs-on: ubuntu-latest | |
env: | |
RUSTDOCFLAGS: -Dwarnings | |
steps: | |
- uses: actions/checkout@master | |
- uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: stable | |
components: rust-docs | |
- uses: swatinem/rust-cache@v2 | |
- run: cargo doc --workspace --no-deps | |
# Build and run tests/doctests/examples on all platforms | |
# FIXME: look into `cargo-hack` which lets you more aggressively | |
# probe all your features and rust versions (see tracing's ci) | |
test: | |
runs-on: ${{ matrix.os }} | |
env: | |
# runtest the installer scripts | |
RUIN_MY_COMPUTER_WITH_INSTALLERS: all | |
CARGO_DIST_GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
strategy: | |
# Test the cross-product of these platforms+toolchains | |
matrix: | |
os: [ubuntu-latest, windows-latest, macos-14] | |
rust: [stable] | |
steps: | |
# Setup tools | |
- uses: actions/checkout@master | |
- uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ matrix.rust }} | |
- uses: swatinem/rust-cache@v2 | |
with: | |
key: ${{ matrix.os }} | |
# install pnpm for npm runtests | |
- run: npm i -g pnpm | |
# Currently there is essentially no difference between default and --all-features, | |
# with the difference essentially being polyfilling a new stdio API for MSRV. | |
# For now avoid --all-features which causes issues with axoproject. | |
# Run the tests/doctests (default features) | |
# - run: cargo test --workspace | |
# env: | |
# PWD: ${{ env.GITHUB_WORKSPACE }} | |
# Run the tests/doctests | |
- run: cargo test --workspace | |
env: | |
PWD: ${{ env.GITHUB_WORKSPACE }} | |
# Test the examples (default features) | |
# - run: cargo test --workspace --examples --bins | |
# env: | |
# PWD: ${{ env.GITHUB_WORKSPACE }} | |
# Test the examples | |
- run: cargo test --workspace --examples --bins | |
env: | |
PWD: ${{ env.GITHUB_WORKSPACE }} |