pytest plugin for snapshot regression testing
Project description
The full documentation for this package are available at https://pytest-regtest.readthedocs.org
About
Introduction
pytest-regtest is a plugin for pytest to implement
regression testing.
Unlike functional testing, regression testing does not test whether the software produces the correct results, but whether it behaves as it did before changes were introduced.
More specifically, pytest-regtest provides snapshot testing, which
implements regression testing by recording data within a test function
and comparing this recorded output to a previously recorded reference
output.
Installation
To install and activate this plugin execute:
$ pip install pytest-regtest
!!! note
`pytest-regtest` provides some functionality specific to `NumPy`,
`pandas`, and `polars`. These dependencies are not installed when
you install `pytest-regtest`. For example, if you are using NumPy
snapshots, we assume that your production code (the code under
test) uses NumPy and therefore should be part of your project's
setup.
Use case 1: Changing code with no or little testing setup yet
If you're working with code that has little or no unit testing, you can use regression testing to ensure that your changes don't break or alter previous results.
Example: This can be useful when working with data analysis scripts, which often start as one long script and then are restructured into different functions as they evolve.
Use case 2: Testing complex data
If a unit tests contains many assert statements to check a complex
data structure you can use regression tests instead.
Example: To test code which ingests data into a database one can use regression tests on textual database dumps.
Use case 3: Testing NumPy arrays or pandas data frames
If your code generates numerical results, such as NumPy arrays,
pandas or polars data frames, you can use pytest-regtest to simply record such
results and test them later, taking into account relative and absolute
tolerances.
Example: A function creates a 10 x 10 matrix. Either you have to write 100 assert statements or you use summary statistics to test your result. In both cases, you may get little debugging information if a test fails.
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 Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pytest_regtest-2.3.6-py3-none-any.whl.
File metadata
- Download URL: pytest_regtest-2.3.6-py3-none-any.whl
- Upload date:
- Size: 17.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3cf8fe982c295b9b22aa9f55cca908dcf49856c35f260bfe18b08eeeadbdd666
|
|
| MD5 |
f39f22d22834939ffb26a2ee48177f4b
|
|
| BLAKE2b-256 |
1c4010b9ef6abd2a07dc6c4e5e61a228b16eea7ef240fadfbd1e502a16b09f7b
|