Pytest plugin for reporting on coverage of the last git commit.
Project description
pytest-gitcov
Extension for pytest to report on the coverage for the lines modified in a given commit or commit range. The vision is to be able to run pytests on a code base before submitting a pull request or code review, to see the lines of code that were modified by you but not covered by unit-tests.
Issues this plugin is trying to resolve
- Ideally the whole code base will have reasonable coverage. Realistically though this is rarely the case with a legacy code base. The repository wide coverage report means little in terms of one developers merge request. The hope is that using this plugin you can shine a light on the code you have touched. Making it easier to spot gaps in unit tests due to code you have written, or modified and identify a gap someone else left and should really be filled.
- Just reporting a list of line ranges covered on the terminal is not much help. I can't remember the line numebers for the functions I've just changed, and working out where the gaps are is time consuming. The HTML report is a lot better for this, but I'd like to have something quick and simple for the terminal.
Install
Nice and easy:
pip install pytest-gitcov
Usage
This is still in very early stages of development and doesn't really do much yet.
After installing, the plugin is automatically found by pytest. At the moment that means that the plugin always runs with each pytest
run and you have to uninstall to disable it. Soon there should be an extra argument that can be used to temporarily disable this. For example, respect the existing pytest-cov
flag (--no-cov
) as well as a new --no-gitcov
flags.
There is also a standalone script available to generate a git coverage report on previous .coverage
DB file, for more info see git-py-coverage --help
.
The plan
So far it just dumps a report at the end of a test run. Report contains the raw info available in the .coverage file (SQLLite3 DB) prsed using the coverage.CoverageData
proxy (https://coverage.readthedocs.io/en/coverage-5.0/api_coveragedata.html#coverage.CoverageData).
The plan is to use git diff --name-status
or git diff --name-only
to get a list of files changed. Then use git blame
to get the lines with line numbers changed for each file in current commit (perhaps with some context as well +/- 3 lines, or maybe later a whole function).
Then show the lines in the commit that are not in the coverage report.
Outcome:
- plugin for pytest that reports on current HEAD commit
- stand-alone git-py-coverage script to run on the last .coverage report. This could be used to generate another report, against a differnt commit without having to run the tests again.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for pytest_gitcov-0.1.5-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 82a81642c9144c6833deec660d047e36b4935b6360b000d765271f8e8a4ad372 |
|
MD5 | 0036bb98f59cc7d95d4e7c0dc1d408cb |
|
BLAKE2b-256 | 5f6b921039f859c04e184464411de62c8ec37e3dcfb63a8512bea063c6433d88 |