4b - Filtering Coverage by Directory
Currently, we collect coverage for each sub-directory. This is useful for projects that run test suites by directory. Codecov automatically merges reports together, but we may want to know coverage as an aggregate of sub-directories.
.├── api│ ├── app.py│ ├── calculator│ │ ├── calculator.py│ │ └── test_calculator.py│ └── smiles│ ├── smiles.py│ └── test_smiles.py└── codecov.yml
The above shows asimplified version of the repository now. If we wanted to know the total coverage for theapi/
directory, we can useComponents
to filter out coverage for files in that directory.
Adding Components
Components are not dependent on the CI/CD workflow and only need to be specified in yourcodecov.yml
file. Add the following to your file.
comment: layout: "condensed_header, diff, flags, components" component_management: individual_components: - component_id: api # this is an identifier that should not be changed name: api # this is a display name, and can be changed freely paths: - api
We are creating a Component calledapi
that will encapsulate all of the coverage in that directory. Create a new commit and push it up to GitHub.
git add .git commit -m 'step4: add Codecov Component'git push origin step4
Remember, in step4a
we set up CI to produce two coverage reportscalculator-coverage.xml
andsmiles-coverage.xml
. Codecov will seamlessly merge those reports together.
After CI/CD runs, create a PR and let's take a look at the PR comment.
Notice the new sectionComponents
that shows the total coverage for theapi/
directory.
Add a coverage step to CI/CD
Now, let's take the scenario that only one test suite is run and uploaded. We may want to know the coverage forcalculator
andsmiles
separately. Let's change the GitHub workflow to do this.
name: API workflowon: [push, pull_request]jobs: build: runs-on: ubuntu-latest name: Test python API steps: - uses: actions/checkout@v4 - uses: actions/setup-python@v2 with: python-version: '3.10' - name: Install requirements run: pip install -r api/requirements.txt - name: Run tests and collect coverage run: pytest --cov - name: Upload coverage reports to Codecov with GitHub Action uses: codecov/codecov-action@v5 env: CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }}
Notice that line 17 is running tests and collecting coverage for the entire repository. Update thecodecov.yml
file to have two Components.
component_management: individual_components: - component_id: api-calculator # this is an identifier that should not be changed name: calculator # this is a display name, and can be changed freely paths: - api/calculator/ - component_id: api-smiles # this is an identifier that should not be changed name: smiles # this is a display name, and can be changed freely paths: - api/smiles/
Now create a new commit and upload to GitHub.
git add .git commit -m 'step4: aggregate tests and split Component'git push origin step4
Now we see that there are two Components that represent thecalculator
andsmiles
directory, respectively.
Merge in the pull request when finished.
Updated 6 months ago