A plugin for pytest to manage expected test failures.
Save the list of failing tests, so that they can be automatically marked as expected failures on future test runs.
You've got a test suite; nicely done! Unfortunately, for completely understandable reasons, a lot of the tests are failing. Someday, you and/or your team will get those tests to pass. For now, though, what you really want is to draw a line in the sand and avoid new test failures. Unfortunately, it's hard to tell when they're introduced because the test suite is already failing. You could get the test suite to pass by applying
pytest.mark.xfail to the existing failures, but there are so many of them.
With this plugin, you can save all of existing failures to a file (the quarantine). On future test runs, this plugin will automatically apply
pytest.mark.xfail to the quarantined tests. Then, the test suite will pass, and any new failures will cause it to fail.
- Python 2.7 or 3.5+
- pytest 4.6 or newer
$ pip install pytest-quarantine
Run your test suite and save the failing tests to
$ pytest --save-quarantine=quarantine.txt ============================= test session starts ============================== ... collected 1380 items ... ---------------------- 661 items saved to quarantine.txt ----------------------- ============== 629 failed, 719 passed, 32 error in 312.56 seconds ==============
quarantine.txt to your version control system.
Run your test suite with the quarantined tests marked as expected failures:
$ pytest --quarantine=quarantine.txt ============================= test session starts ============================== ... collected 1380 items added mark.xfail to 661 of 661 items from quarantine.txt ... ================== 719 passed, 661 xfailed in 300.51 seconds ===================
When the expected failures eventually pass (i.e., they get counted as
xpassed), they can be removed manually from
quarantine.txt, or automatically using
--save-quarantine. Note that the latter will overwrite the contents of the quarantine, so it's best to only use it when running the entire test suite.
Please submit questions, bug reports, and feature requests in the issue tracker.
Improvements to the code and documentation are greatly appreciated. See How to contribute for details.
Code of conduct
Everyone interacting with this project is expected to follow the Contributor Covenant.
Distributed under the terms of the MIT license.
This project was initially developed at EnergySage to aid our migration to Python 3. We hope other people find it helpful.
Some other helpful resources were:
- Starting an Open Source Project | Open Source Guides
- Testing & Packaging | Hynek Schlawack
- Maintaining a Python Project When It’s Not Your Job | Hynek Schlawack
- Python Testing with pytest | Brian Okken | The Pragmatic Bookshelf
- Developing better test suites for pytest plugins | Raphael Pierzina
- GitHub search for examples from
org:pytest-dev org:pypa org:pycqa org:pallets org:encode