an incremental test runner (pytest plugin)
Project description
pytest-incremental
an incremental test runner (pytest plug-in)
What is an “incremental test runner” ?
The idea is to execute your tests faster by executing not all of them but only the “required” ones.
When talking about build-tools it is common to refer to the terms:
initial (full) build - all files are compiled
incremental build (or partial rebuild) - just changed files are compiled
no-op build - no files are compiled (none changed since last execution)
So an “incremental test runner” will only re-execute tests that were affected by changes in the source code since last successful execution.
How it works ?
pytest-incremental is a pytest plug-in. So if you can run your test suite with pytest you can use pytest-incremental.
Note that pytest has support to run standard unittest’s and nose’s tests. So even if you don’t use pytest as a test framework you might be able to use it as a test runner.
The plug-in will analyze your python source files and through its imports define the dependencies of the modules. doit is used to keep track of the dependencies and save results. The plug-in will modify how pytest collect your tests. pytest do the rest of the job of actually running the tests and reporting the results.
Install
pytest-incremental is tested on python 2.6, 2.7.
pip install pytest-incremental`
python setup.py install
local installation
You can also just grab the plug-in module file and put in your project path. Then enable it (check pytest docs).
Usage
Just pass the parameter --incremental when calling from the command line:
$ py.test --incremental
You can also enable it by default adding the following line to your pytest.ini:
[pytest] addopts = --incremental
watched packages
By default all modules collected by py.test will be used as dependencies if imported. In order to limit or extend the watched folders you must use the parameter --watch-path
This can be used in case you want to watch for changes in modules that are in another project. For example if you are testing my_lib and want to check for changes in dependencies from your py3rd package:
$ py.test --incremental --watch-pkg my_lib --watch-pkg ../py3rd-trunk/py3rd
Note: If you want to execute tests from a single file like:
$ py.test tests/test_foo.py
It is required to use --watch-path because the source files will not be collected by py.test
You should call:
$ py.test --incremental --watch-pkg my_lib tests/test_foo.py
dependencies
You can check what are the actual dependencies detected by running the command:
$ py.test --list-dependencies
for better visualization you can create a graph file in “dot” format (see graphviz
$ py.test --graph-dependencies $ dot -Tpng -o imports.png imports.dot
You can also check what are the outdated tests without executing them:
$ py.test --list-outdated
Limitations
pytest-incremental looks for imports recursively to find dependencies (using AST). But given the very dynamic nature of python there are still some cases that a module can be affected by a module that are not detected.
from package import * modules imported from __all__ in a package are not counted as a dependency
modules imported not using the import statement
modules not explicitly imported but used at run-time (i.e. conftest.py when running your tests with pytest)
monkey-patching. (i.e. A imports X. B monkey-patches X. In this case A might depend on B)
others ?
Project Details
Project code + issue track on bitbucket
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
File details
Details for the file pytest-incremental-0.3.0.tar.gz
.
File metadata
- Download URL: pytest-incremental-0.3.0.tar.gz
- Upload date:
- Size: 8.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e02fd0ce7f9b8479f39bd6870e98908d4ef81f187530c8501fdaab735d7905a0 |
|
MD5 | e5e643e31d0ffd58c6e9bca66cc6298f |
|
BLAKE2b-256 | 17c7995268834df02e41ee3991f528a729cf25e3fcd59cd6da6e093e285c298c |