A pytest plugin that helps better distinguishing real test failures from setup flakiness.
Project description
A pytest plugin that helps better distinguishing real test failures from setup flakiness.
Features
Re-running only the setup-phase on failure
Additional test-outcome: FAILED_TO_VERIFY if a failure happened in setup phase and prevented the actual test-logic from executing.
Installation
You can install the plugin using the following command:
$ pip install pytest-failed-to-verify
Usage
Based on the existing pytest-rerunfailures plugin we added the following functionality:
Once installed the plugin provides an additional test outcome failed-to-verify in case a test fails in the setup-phase, additionaly you are able to control the amount of re-runs specifically for the setup phase:
$ pytest --rerun-setup 1
The core functionality of pytest-rerunfailures can be used also with this plugin.
If you are interested in re-running the whole test you can use the following options globally:
$ pytest --reruns 5 --reruns-delay 1
or mark a single test as flaky like this:
@pytest.mark.flaky(reruns=5, reruns_delay=2)
def test_example():
import random
assert random.choice([True, False])
What’s the idea behind it?
A pytest test consists of three phases (setup, call, teardown). Usually only the call phase contains the actual tested business logic and the outcome of this phase gives the most valuable result.
The setup phase is used to provide the pre-conditions for the test and might be even larger than the test.
Assuming that the flakiness of a test is evenly distributed between the lines of code a test is executing, having a large setup phase means an error due to flakiness is most likely to happen there. If that’s the case a test fails but is leaving you with no relevant test-outcome: the actual test did not happen.
So if the setup fails the result of a test will be failed-to-verify rather than failed.
Additionally re-running only the setup phase is a mechanism that assures the code that is testing the actual business logic (call-phase) is actually executed and provides you a valid test outcome without suffering from a flaky setup phase.
I want to know more about it
If you found this repo we wanted to let you know that we at gastrofix are also fighting the battle against flaky tests. Doing research we came across this very usefull and detailed article on how Dropbox is dealing with flaky tests in their CI (Dropbox: How we’re winning the battle against flaky tests ).
This plugin is part of our approach of adapting their mechanism to deal with flaky tests.
Credits
Credits to https://github.com/pytest-dev as some of the code was taken and re-used from the pytest-rerunfailures plugin. We used it as a starting point to implelement the additionally needed functionality.
Known issues
Because of the similarity it does not work well together with pytest-rerunfailures. If you still need to be able to rerun the complete test on case of an error you can do this as well using this plugin.
Contributing
Contributions are very welcome. Tests can be run with tox, please ensure the coverage at least stays the same before you submit a pull request.
Issues
If you encounter any problems, please file an issue along with a detailed description.
This pytest plugin was generated with Cookiecutter along with @hackebrot’s cookiecutter-pytest-plugin template.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Hashes for pytest-failed-to-verify-0.1.4.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4f0dbff8b922cc4dac30baa65525ba86a9a90536e9956796f572617917a37df0 |
|
MD5 | 075d72af37d6712fb92bd38f7caa7373 |
|
BLAKE2b-256 | 315629887d49c7e5af3b358c27ba7c8f27a6ebe0e0617a93adbc172e25711fb9 |