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 a simplified version of the repository now. If we wanted to know the total coverage for the api/
directory, we can use Components
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 your codecov.yml
file. Add the following to your file.
comment:
layout: "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 called api
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
Create a new file api/smiles/smiles.py
Now create a test file api/smiles/test_smiles.py
Add a coverage step to CI/CD
Let's add a test and coverage step for the api/smiles
directory. In your .github/workflows/ci.yml
file, replace the file with the below code
We will now be producing two coverage reports calculator-coverage.xml
and smiles-coverage.xml
. Codecov will seamlessly merge those reports together. Create a pull request
After CI/CD runs, let's take a look at the PR comment.
data:image/s3,"s3://crabby-images/be59c/be59c216d7c195070f9a6cd2a2ea023b03c222c8" alt="4.png 919"
Notice the new section Components
that shows the total coverage for the api/
directory.
Now, let's take the scenario that only one test suite is run and uploaded. We may want to know the coverage for calculator
and `smiles separately. Let's change the GitHub workflow to do this.
name: API workflow
on: [push, pull_request]
jobs:
build:
runs-on: ubuntu-latest
name: Test python API
steps:
- uses: actions/checkout@v3
- uses: actions/setup-python@v2
with:
python-version: '3.11'
- 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@v3
Notice that line 17 is running tests and collecting coverage for the entire repository. Update the codecov.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 the calculator
and smiles
directory, respectively.
data:image/s3,"s3://crabby-images/c7d1b/c7d1b722f6952f2b27eb4dcee80966688437b73c" alt="5.png 931"
Merge in the pull request when finished.
Updated about 2 years ago