From 1250758b74e7b0f9a41a9472b13aa06e7ebe8ad3 Mon Sep 17 00:00:00 2001 From: Varik Matevosyan Date: Thu, 31 Oct 2024 15:55:38 +0400 Subject: [PATCH] collect coverage for lantern_extras using grcov --- .github/workflows/build.yaml | 4 ++-- .github/workflows/test.yaml | 27 ++++++++++++++++++--------- 2 files changed, 20 insertions(+), 11 deletions(-) diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index a92764e7..7087b117 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -66,7 +66,7 @@ jobs: - name: Build Lantern CLI id: build_cli run: sudo sh -c "PACKAGE_CLI=1 GITHUB_OUTPUT=$GITHUB_OUTPUT ./ci/scripts/build-extras.sh" - if: ${{ matrix.postgres == 15 }} # run only once + if: ${{ matrix.postgres == 17 }} # run only once - name: Upload archive package artifacts if: ${{ github.event_name == 'workflow_dispatch' && inputs.create_release }} uses: actions/upload-artifact@v4 @@ -74,7 +74,7 @@ jobs: name: ${{ steps.build.outputs.archive_package_name }} path: ${{ steps.build.outputs.archive_package_path }} - name: Upload Lantern CLI artifacts - if: ${{ matrix.postgres == 15 && github.event_name == 'workflow_dispatch' && inputs.create_release }} # run only once + if: ${{ matrix.postgres == 17 && github.event_name == 'workflow_dispatch' && inputs.create_release }} # run only once uses: actions/upload-artifact@v4 with: name: ${{ steps.build_cli.outputs.cli_package_name }} diff --git a/.github/workflows/test.yaml b/.github/workflows/test.yaml index b63455c0..412ca171 100644 --- a/.github/workflows/test.yaml +++ b/.github/workflows/test.yaml @@ -65,13 +65,13 @@ jobs: env: PG_VERSION: ${{ matrix.postgres }} BRANCH_NAME: ${{ github.head_ref || github.ref_name }} - ENABLE_COVERAGE: ${{ (startsWith(matrix.os, 'ubuntu') && matrix.postgres == 15) && '1' || '0' }} + ENABLE_COVERAGE: ${{ (startsWith(matrix.os, 'ubuntu') && matrix.postgres == 17) && '1' || '0' }} - name: Run tests linux id: test-linux run: sudo su postgres -c "PG_VERSION=$PG_VERSION ./ci/scripts/run-tests-linux.sh" env: PG_VERSION: ${{ matrix.postgres }} - ENABLE_COVERAGE: ${{ (startsWith(matrix.os, 'ubuntu') && matrix.postgres == 15) && '1' || '0' }} + ENABLE_COVERAGE: ${{ (startsWith(matrix.os, 'ubuntu') && matrix.postgres == 17) && '1' || '0' }} if: ${{ !startsWith(matrix.os, 'mac') }} # integration tests - name: Set LANTERN_CLI_PATH variable @@ -92,7 +92,7 @@ jobs: - name: Collect coverage files id: collect-cov-files run: sudo su postgres -c "cd /tmp/lantern/lantern_hnsw/build && make cover" - if: ${{ startsWith(matrix.os, 'ubuntu') && matrix.postgres == 15 }} + if: ${{ startsWith(matrix.os, 'ubuntu') && matrix.postgres == 17 }} - name: Run update tests linux id: update-test-linux @@ -137,7 +137,7 @@ jobs: /tmp/pg-out.log /tmp/pg-error.log - name: Upload lantern coverage - if: ${{ startsWith(matrix.os, 'ubuntu') && matrix.postgres == 15 }} + if: ${{ startsWith(matrix.os, 'ubuntu') && matrix.postgres == 17 }} uses: actions/upload-artifact@v4 with: name: lantern-lcov.info @@ -167,8 +167,6 @@ jobs: workspaces: | lantern_cli lantern_extras - - name: Install cargo-llvm-cov - uses: taiki-e/install-action@cargo-llvm-cov - name: Setup test env run: sudo su -c "PG_VERSION=$PG_VERSION SETUP_ENV=1 SETUP_POSTGRES=1 SETUP_TESTS=1 USE_SOURCE=1 ./ci/scripts/build-extras.sh" env: @@ -178,7 +176,9 @@ jobs: cargo install cargo-pgrx --version 0.12.7 cargo pgrx init "--pg$PG_VERSION" /usr/bin/pg_config sed -i -e "s/default = .*/default=[\"pg${PG_VERSION}\"]/" lantern_extras/Cargo.toml - RUSTFLAGS="--cfg profile=\"ci-build\"" cargo pgrx install --sudo --pg-config /usr/bin/pg_config --package lantern_extras + export RUSTFLAGS='--cfg profile="ci-build" -C instrument-coverage' + export LLVM_PROFILE_FILE="$(pwd)/coverage-%p-%m.profraw" + cargo pgrx install --sudo --pg-config /usr/bin/pg_config --package lantern_extras env: PG_VERSION: ${{ matrix.postgres }} - name: Run postgres @@ -192,14 +192,23 @@ jobs: env: PG_VERSION: ${{ matrix.postgres }} - name: Run tests - run: cargo llvm-cov --workspace --lcov --output-path lantern-extras-lcov.info + run: | + export RUSTFLAGS='--cfg profile="ci-build" -C instrument-coverage' + export LLVM_PROFILE_FILE="$(pwd)/coverage-%p-%m.profraw" + cargo test env: OPENAI_TOKEN: ${{ secrets.OPENAI_TOKEN }} COHERE_TOKEN: ${{ secrets.COHERE_TOKEN }} DB_URL: "postgres://postgres@127.0.0.1:5432/postgres" + - name: Collect coverage + if: ${{ startsWith(matrix.os, 'ubuntu') }} + run: | + cargo install grcov + rustup component add llvm-tools-preview + grcov *.profraw -s . --binary-path target/debug -t lcov --branch -o lantern-extras-lcov.info --ignore "{target/debug/build/*,lantern_cli/tests/*,lantern_cli/src/main.rs}" - name: Upload lantern_extras coverage uses: actions/upload-artifact@v4 - if: ${{ startsWith(matrix.os, 'ubuntu') && matrix.postgres == 15}} + if: ${{ startsWith(matrix.os, 'ubuntu') && matrix.postgres == 17}} with: name: lantern-extras-lcov.info path: ./lantern-extras-lcov.info