From d1e854ee463e8c959e044fdc0648bdbeedca1ec7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daniel=20M=C3=BCller?= Date: Fri, 30 Sep 2022 20:56:20 -0700 Subject: [PATCH] Switch to using cargo llvm-cov for code coverage assessment Our code coverage collection runs have repeatedly failed because of a what appears to be a bug in the actions-rs/tarpaulin implementation. This action, it turns out, has actually been (soft?) deprecated [0]. Attempting to switch to installing cargo-tarpauling directly takes ages, and we already know that we would rather avoid handling caching in GitHub Actions, because of their API mess. However, it appears as if cargo llvm-cov may be usable by now, and is generally said to provide more accurate coverage information. Thus, with this change we switch over to using it for collection of code coverage. Note that cargo-tarpaulin also seems to support using LLVM coverage as a backend, but it still suffers from the aforementioned issues. [0] https://github.com/actions-rs/tarpaulin/issues/6 --- .github/workflows/ci.yml | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index a9d27e4..2f619d8 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -46,19 +46,14 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v3 - - uses: actions-rs/toolchain@v1 - with: - toolchain: stable - override: true - - uses: actions-rs/tarpaulin@v0.1 - with: - version: latest - out-type: Xml - args: '--features=serde,num-v04 --no-default-features' + - name: Install cargo-llvm-cov + uses: taiki-e/install-action@cargo-llvm-cov + - name: Test and gather coverage + run: cargo llvm-cov --lcov --output-path lcov.info --features=serde,num-v04 --no-default-features - name: Upload code coverage results uses: codecov/codecov-action@v3 with: - files: cobertura.xml + files: lcov.info clippy: name: Lint with clippy runs-on: ubuntu-latest