Factor out _validate_parametrize_spelling

This makes it easier to read `pytest_generate_tests`.
This commit is contained in:
Daniel Hahler 2019-11-18 16:35:34 +01:00
parent a2d48332fc
commit 91dec8e2bf
1 changed files with 8 additions and 5 deletions

View File

@ -119,14 +119,17 @@ def pytest_cmdline_main(config):
return 0 return 0
def pytest_generate_tests(metafunc): def _validate_parametrize_spelling(metafunc):
# those alternative spellings are common - raise a specific error to alert """Raise a specific error for common misspellings of "parametrize"."""
# the user for mark_name in ["parameterize", "parametrise", "parameterise"]:
alt_spellings = ["parameterize", "parametrise", "parameterise"]
for mark_name in alt_spellings:
if metafunc.definition.get_closest_marker(mark_name): if metafunc.definition.get_closest_marker(mark_name):
msg = "{0} has '{1}' mark, spelling should be 'parametrize'" msg = "{0} has '{1}' mark, spelling should be 'parametrize'"
fail(msg.format(metafunc.function.__name__, mark_name), pytrace=False) fail(msg.format(metafunc.function.__name__, mark_name), pytrace=False)
def pytest_generate_tests(metafunc):
_validate_parametrize_spelling(metafunc)
for marker in metafunc.definition.iter_markers(name="parametrize"): for marker in metafunc.definition.iter_markers(name="parametrize"):
metafunc.parametrize(*marker.args, **marker.kwargs) metafunc.parametrize(*marker.args, **marker.kwargs)