A pytest plugin to generate parametrized tests from external files, with (optional) automated regeneration of expected output on failures.
Simply create a text file with an available format:
yaml format:
name1:
description: optional description
input: |-
input content
expected: |-
expected output content
name2:
description: optional description
input: |-
input content
expected: |-
expected output contentdot format (default):
[name1] optional description
.
input content
.
expected output content
.
[name2] optional description
.
input content
.
expected output content
.
Then, use the param_file pytest marker to create a parametrized test:
from pathlib import Path
import pytest
import my_function
PATH = Path(__file__).parent.joinpath("test_file.txt")
@pytest.mark.param_file(PATH, fmt="dot")
def test_function(file_params):
assert my_function(file_params.content) == file_params.expectedand the output will be:
$ pytest -v test_file.py
...
test_file.py::test_function[1-name1] PASSED
test_file.py::test_function[8-name2] FAILEDAlternatively use the assert_expected method, which will can handle more rich assertion features:
@pytest.mark.param_file(PATH, fmt="dot")
def test_function(file_params):
actual = my_function(file_params.content)
assert file_params.assert_expected(actual, rstrip=True)$ pytest -v test_file.py
...
test_file.py::test_function[1-name1] PASSED
test_file.py::test_function[8-name2] FAILED
...
E AssertionError: Actual does not match expected
E --- /path/to/test_file.txt:8
E +++ (actual)
E @@ -1 +1 @@
E -content
E +otherInstall from PyPI:
$ pip install pytest-param-filesor install locally (for development):
$ pip install -e .Running pytest with the --regen-file-failure option will regenerate the parameter file with actual outputs of assert_expected, if any test fails.