From 413d2429d60d56a8f145ec855c7d6fefc50d8e59 Mon Sep 17 00:00:00 2001 From: Arpad Borsos Date: Mon, 11 Nov 2024 12:31:49 +0100 Subject: [PATCH] Update CI and use `nextest` This updates the CI definitions a bit: - Invokes `rustup` directly instead of using an action - Updates the `setup-python` action to the latest version - Adds a separate `doctest` run to run doctests and emit `cargo doc` errors - Switches to `nextest` for running test, which also has builtin junit output - Always run tests with coverage --- .config/nextest.toml | 2 + .github/workflows/ci.yml | 99 +++++++++++++++------------------------- .gitignore | 2 + 3 files changed, 42 insertions(+), 61 deletions(-) create mode 100644 .config/nextest.toml diff --git a/.config/nextest.toml b/.config/nextest.toml new file mode 100644 index 0000000..2db4b04 --- /dev/null +++ b/.config/nextest.toml @@ -0,0 +1,2 @@ +[profile.default.junit] +path = "core-test-results.xml" diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 07472f5..ae5cf2e 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -6,6 +6,9 @@ on: - main pull_request: +env: + RUSTFLAGS: -Dwarnings + concurrency: group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} cancel-in-progress: true @@ -15,81 +18,55 @@ jobs: name: Lint (rustfmt + clippy) runs-on: ubuntu-latest steps: - - name: Checkout - uses: actions/checkout@v4 - - name: Install Rust - uses: dtolnay/rust-toolchain@nightly - with: - toolchain: nightly - components: clippy, rustfmt - - name: Run lint - run: make lint.rust + - uses: actions/checkout@v4 + + - run: rustup toolchain install nightly --profile minimal --component rustfmt --component clippy --no-self-update + + - run: cargo fmt --all -- --check + - run: cargo clippy --all-features --workspace --tests --examples -- -D clippy::all lint-python: name: Lint Python (ruff, mypy) runs-on: ubuntu-latest steps: - - name: Checkout - uses: actions/checkout@v4 - - uses: actions/setup-python@v3 - - name: Set up venv - run: make ci.setup_venv - - name: Build and run lint - run: | + - uses: actions/checkout@v4 + + - uses: actions/setup-python@v5 + - run: make ci.setup_venv + + - run: | maturin develop make lint.python - test: - name: Test + doctest: + name: Documentation (and Tests) runs-on: ubuntu-latest - strategy: - fail-fast: false + env: + RUSTDOCFLAGS: -Dwarnings steps: - - name: Checkout - uses: actions/checkout@v4 - - name: Install Rust - uses: dtolnay/rust-toolchain@nightly - with: - toolchain: nightly - - name: Run Rust tests - run: | - cargo test + - uses: actions/checkout@v4 - - uses: actions/setup-python@v3 - - name: Set up venv - run: make ci.setup_venv - - name: Run Python tests - run: | - maturin develop - pytest - - # This job runs tests, generates coverage data, and generates JUnit test - # results in a single test invocation and then uploads it all to Codecov. - # However, it doesn't print test results to stdout. If Codecov's failed test - # reporting is solid and we never need to see the results in the CI logs, we - # can delete the "normal" test step and just use this. - test-for-codecov: - name: Test (Upload to Codecov) + - run: rustup toolchain install nightly --profile minimal --no-self-update + + - run: cargo test --workspace --all-features --doc + - run: cargo doc --workspace --all-features --document-private-items --no-deps + + test: + name: Test runs-on: ubuntu-latest - strategy: - fail-fast: false steps: - - name: Checkout - uses: actions/checkout@v4 - - name: Install Rust - uses: dtolnay/rust-toolchain@nightly - with: - toolchain: nightly - - name: Install `cargo llvm-cov` - uses: taiki-e/install-action@cargo-llvm-cov - - name: Run tests - run: | - cargo install cargo2junit - cargo llvm-cov --lcov --output-path core.lcov -- -Z unstable-options --format json --report-time | cargo2junit > core-test-results.xml + - uses: actions/checkout@v4 + + - run: rustup toolchain install nightly --profile minimal --no-self-update + - uses: taiki-e/install-action@cargo-llvm-cov + - uses: taiki-e/install-action@nextest + + - run: cargo llvm-cov nextest --lcov --output-path core.lcov --workspace --all-features --all-targets + - run: mv target/nextest/default/core-test-results.xml . + + - uses: actions/setup-python@v5 + - run: make ci.setup_venv - - uses: actions/setup-python@v3 - - name: Set up venv - run: make ci.setup_venv - name: Run Python tests run: | # Clear prior profile data diff --git a/.gitignore b/.gitignore index e807452..104f46e 100644 --- a/.gitignore +++ b/.gitignore @@ -28,3 +28,5 @@ __pycache__/ .git lcov.info +/*test-results.xml +/*.lcov \ No newline at end of file