issue #308
address some comments by @hpk42 on 0b9d82e : - move tests into their own class, rename - add test showing metafunc.parametrize called in pytest_generate_tests rather than as decorator - add test and fix single-argname case - convert two loops into one in parametrize() also - renamed 'input' to 'n', since 'input' is a built-in
This commit is contained in:
parent
5373a63008
commit
ee65ca10f4
|
@ -671,24 +671,27 @@ class Metafunc(FuncargnamesCompatAttr):
|
||||||
It will also override any fixture-function defined scope, allowing
|
It will also override any fixture-function defined scope, allowing
|
||||||
to set a dynamic scope using test context or configuration.
|
to set a dynamic scope using test context or configuration.
|
||||||
"""
|
"""
|
||||||
|
# remove any marks applied to individual tests instances
|
||||||
|
# these marks will be applied in Function init
|
||||||
|
newkeywords = {}
|
||||||
|
strippedargvalues = []
|
||||||
|
for i, argval in enumerate(argvalues):
|
||||||
|
if isinstance(argval, MarkDecorator):
|
||||||
|
# convert into a mark without the test content mixed in
|
||||||
|
newmark = MarkDecorator(argval.markname, argval.args[:-1], argval.kwargs)
|
||||||
|
newkeywords[i] = {newmark.markname: newmark}
|
||||||
|
strippedargvalues.append(argval.args[-1])
|
||||||
|
else:
|
||||||
|
newkeywords[i] = {}
|
||||||
|
strippedargvalues.append(argval)
|
||||||
|
argvalues = strippedargvalues
|
||||||
|
|
||||||
if not isinstance(argnames, (tuple, list)):
|
if not isinstance(argnames, (tuple, list)):
|
||||||
argnames = (argnames,)
|
argnames = (argnames,)
|
||||||
argvalues = [(val,) for val in argvalues]
|
argvalues = [(val,) for val in argvalues]
|
||||||
if not argvalues:
|
if not argvalues:
|
||||||
argvalues = [(_notexists,) * len(argnames)]
|
argvalues = [(_notexists,) * len(argnames)]
|
||||||
|
|
||||||
# these marks/keywords will be applied in Function init
|
|
||||||
newkeywords = {}
|
|
||||||
for i, argval in enumerate(argvalues):
|
|
||||||
newkeywords[i] = {}
|
|
||||||
if isinstance(argval, MarkDecorator):
|
|
||||||
# convert into a mark without the test content mixed in
|
|
||||||
newmark = MarkDecorator(argval.markname, argval.args[:-1], argval.kwargs)
|
|
||||||
newkeywords[i] = {newmark.markname: newmark}
|
|
||||||
|
|
||||||
argvalues = [av.args[-1] if isinstance(av, MarkDecorator) else av
|
|
||||||
for av in argvalues]
|
|
||||||
|
|
||||||
if scope is None:
|
if scope is None:
|
||||||
scope = "subfunction"
|
scope = "subfunction"
|
||||||
scopenum = scopes.index(scope)
|
scopenum = scopes.index(scope)
|
||||||
|
|
|
@ -577,19 +577,21 @@ class TestMetafuncFunctional:
|
||||||
"*3 passed*"
|
"*3 passed*"
|
||||||
])
|
])
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.issue308
|
@pytest.mark.issue308
|
||||||
def test_mark_on_individual_parametrize_instance(self, testdir):
|
class TestMarkersWithParametrization:
|
||||||
|
def test_simple_mark(self, testdir):
|
||||||
s = """
|
s = """
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
@pytest.mark.foo
|
@pytest.mark.foo
|
||||||
@pytest.mark.parametrize(("input", "expected"), [
|
@pytest.mark.parametrize(("n", "expected"), [
|
||||||
(1, 2),
|
(1, 2),
|
||||||
pytest.mark.bar((1, 3)),
|
pytest.mark.bar((1, 3)),
|
||||||
(2, 3),
|
(2, 3),
|
||||||
])
|
])
|
||||||
def test_increment(input, expected):
|
def test_increment(n, expected):
|
||||||
assert input + 1 == expected
|
assert n + 1 == expected
|
||||||
"""
|
"""
|
||||||
items = testdir.getitems(s)
|
items = testdir.getitems(s)
|
||||||
assert len(items) == 3
|
assert len(items) == 3
|
||||||
|
@ -599,18 +601,17 @@ class TestMetafuncFunctional:
|
||||||
assert 'bar' in items[1].keywords
|
assert 'bar' in items[1].keywords
|
||||||
assert 'bar' not in items[2].keywords
|
assert 'bar' not in items[2].keywords
|
||||||
|
|
||||||
@pytest.mark.issue308
|
def test_select_based_on_mark(self, testdir):
|
||||||
def test_select_individual_parametrize_instance_based_on_mark(self, testdir):
|
|
||||||
s = """
|
s = """
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
@pytest.mark.parametrize(("input", "expected"), [
|
@pytest.mark.parametrize(("n", "expected"), [
|
||||||
(1, 2),
|
(1, 2),
|
||||||
pytest.mark.foo((2, 3)),
|
pytest.mark.foo((2, 3)),
|
||||||
(3, 4),
|
(3, 4),
|
||||||
])
|
])
|
||||||
def test_increment(input, expected):
|
def test_increment(n, expected):
|
||||||
assert input + 1 == expected
|
assert n + 1 == expected
|
||||||
"""
|
"""
|
||||||
testdir.makepyfile(s)
|
testdir.makepyfile(s)
|
||||||
rec = testdir.inline_run("-m", 'foo')
|
rec = testdir.inline_run("-m", 'foo')
|
||||||
|
@ -619,41 +620,19 @@ class TestMetafuncFunctional:
|
||||||
assert len(skipped) == 0
|
assert len(skipped) == 0
|
||||||
assert len(fail) == 0
|
assert len(fail) == 0
|
||||||
|
|
||||||
@pytest.mark.xfail("is this important to support??")
|
|
||||||
@pytest.mark.issue308
|
|
||||||
def test_nested_marks_on_individual_parametrize_instance(self, testdir):
|
|
||||||
s = """
|
|
||||||
import pytest
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(("input", "expected"), [
|
|
||||||
(1, 2),
|
|
||||||
pytest.mark.foo(pytest.mark.bar((1, 3))),
|
|
||||||
(2, 3),
|
|
||||||
])
|
|
||||||
def test_increment(input, expected):
|
|
||||||
assert input + 1 == expected
|
|
||||||
"""
|
|
||||||
items = testdir.getitems(s)
|
|
||||||
assert len(items) == 3
|
|
||||||
for mark in ['foo', 'bar']:
|
|
||||||
assert mark not in items[0].keywords
|
|
||||||
assert mark in items[1].keywords
|
|
||||||
assert mark not in items[2].keywords
|
|
||||||
|
|
||||||
@pytest.mark.xfail(reason="is this important to support??")
|
@pytest.mark.xfail(reason="is this important to support??")
|
||||||
@pytest.mark.issue308
|
def test_nested_marks(self, testdir):
|
||||||
def test_nested_marks_on_individual_parametrize_instance(self, testdir):
|
|
||||||
s = """
|
s = """
|
||||||
import pytest
|
import pytest
|
||||||
mastermark = pytest.mark.foo(pytest.mark.bar)
|
mastermark = pytest.mark.foo(pytest.mark.bar)
|
||||||
|
|
||||||
@pytest.mark.parametrize(("input", "expected"), [
|
@pytest.mark.parametrize(("n", "expected"), [
|
||||||
(1, 2),
|
(1, 2),
|
||||||
mastermark((1, 3)),
|
mastermark((1, 3)),
|
||||||
(2, 3),
|
(2, 3),
|
||||||
])
|
])
|
||||||
def test_increment(input, expected):
|
def test_increment(n, expected):
|
||||||
assert input + 1 == expected
|
assert n + 1 == expected
|
||||||
"""
|
"""
|
||||||
items = testdir.getitems(s)
|
items = testdir.getitems(s)
|
||||||
assert len(items) == 3
|
assert len(items) == 3
|
||||||
|
@ -662,90 +641,123 @@ class TestMetafuncFunctional:
|
||||||
assert mark in items[1].keywords
|
assert mark in items[1].keywords
|
||||||
assert mark not in items[2].keywords
|
assert mark not in items[2].keywords
|
||||||
|
|
||||||
@pytest.mark.issue308
|
def test_simple_xfail(self, testdir):
|
||||||
def test_simple_xfail_on_individual_parametrize_instance(self, testdir):
|
|
||||||
s = """
|
s = """
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
@pytest.mark.parametrize(("input", "expected"), [
|
@pytest.mark.parametrize(("n", "expected"), [
|
||||||
(1, 2),
|
(1, 2),
|
||||||
pytest.mark.xfail((1, 3)),
|
pytest.mark.xfail((1, 3)),
|
||||||
(2, 3),
|
(2, 3),
|
||||||
])
|
])
|
||||||
def test_increment(input, expected):
|
def test_increment(n, expected):
|
||||||
assert input + 1 == expected
|
assert n + 1 == expected
|
||||||
"""
|
"""
|
||||||
testdir.makepyfile(s)
|
testdir.makepyfile(s)
|
||||||
reprec = testdir.inline_run()
|
reprec = testdir.inline_run()
|
||||||
# xfail is skip??
|
# xfail is skip??
|
||||||
reprec.assertoutcome(passed=2, skipped=1)
|
reprec.assertoutcome(passed=2, skipped=1)
|
||||||
|
|
||||||
@pytest.mark.issue308
|
def test_simple_xfail_single_argname(self, testdir):
|
||||||
def test_xfail_with_arg_on_individual_parametrize_instance(self, testdir):
|
|
||||||
s = """
|
s = """
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
@pytest.mark.parametrize(("input", "expected"), [
|
@pytest.mark.parametrize("n", [
|
||||||
|
2,
|
||||||
|
pytest.mark.xfail(3),
|
||||||
|
4,
|
||||||
|
])
|
||||||
|
def test_isEven(n):
|
||||||
|
assert n % 2 == 0
|
||||||
|
"""
|
||||||
|
testdir.makepyfile(s)
|
||||||
|
reprec = testdir.inline_run()
|
||||||
|
reprec.assertoutcome(passed=2, skipped=1)
|
||||||
|
|
||||||
|
def test_xfail_with_arg(self, testdir):
|
||||||
|
s = """
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
@pytest.mark.parametrize(("n", "expected"), [
|
||||||
(1, 2),
|
(1, 2),
|
||||||
pytest.mark.xfail("sys.version > 0")((1, 3)),
|
pytest.mark.xfail("sys.version > 0")((1, 3)),
|
||||||
(2, 3),
|
(2, 3),
|
||||||
])
|
])
|
||||||
def test_increment(input, expected):
|
def test_increment(n, expected):
|
||||||
assert input + 1 == expected
|
assert n + 1 == expected
|
||||||
"""
|
"""
|
||||||
testdir.makepyfile(s)
|
testdir.makepyfile(s)
|
||||||
reprec = testdir.inline_run()
|
reprec = testdir.inline_run()
|
||||||
reprec.assertoutcome(passed=2, skipped=1)
|
reprec.assertoutcome(passed=2, skipped=1)
|
||||||
|
|
||||||
@pytest.mark.issue308
|
def test_xfail_with_kwarg(self, testdir):
|
||||||
def test_xfail_with_kwarg_on_individual_parametrize_instance(self, testdir):
|
|
||||||
s = """
|
s = """
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
@pytest.mark.parametrize(("input", "expected"), [
|
@pytest.mark.parametrize(("n", "expected"), [
|
||||||
(1, 2),
|
(1, 2),
|
||||||
pytest.mark.xfail(reason="some bug")((1, 3)),
|
pytest.mark.xfail(reason="some bug")((1, 3)),
|
||||||
(2, 3),
|
(2, 3),
|
||||||
])
|
])
|
||||||
def test_increment(input, expected):
|
def test_increment(n, expected):
|
||||||
assert input + 1 == expected
|
assert n + 1 == expected
|
||||||
"""
|
"""
|
||||||
testdir.makepyfile(s)
|
testdir.makepyfile(s)
|
||||||
reprec = testdir.inline_run()
|
reprec = testdir.inline_run()
|
||||||
reprec.assertoutcome(passed=2, skipped=1)
|
reprec.assertoutcome(passed=2, skipped=1)
|
||||||
|
|
||||||
@pytest.mark.issue308
|
def test_xfail_with_arg_and_kwarg(self, testdir):
|
||||||
def test_xfail_with_arg_and_kwarg_on_individual_parametrize_instance(self, testdir):
|
|
||||||
s = """
|
s = """
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
@pytest.mark.parametrize(("input", "expected"), [
|
@pytest.mark.parametrize(("n", "expected"), [
|
||||||
(1, 2),
|
(1, 2),
|
||||||
pytest.mark.xfail("sys.version > 0", reason="some bug")((1, 3)),
|
pytest.mark.xfail("sys.version > 0", reason="some bug")((1, 3)),
|
||||||
(2, 3),
|
(2, 3),
|
||||||
])
|
])
|
||||||
def test_increment(input, expected):
|
def test_increment(n, expected):
|
||||||
assert input + 1 == expected
|
assert n + 1 == expected
|
||||||
"""
|
"""
|
||||||
testdir.makepyfile(s)
|
testdir.makepyfile(s)
|
||||||
reprec = testdir.inline_run()
|
reprec = testdir.inline_run()
|
||||||
reprec.assertoutcome(passed=2, skipped=1)
|
reprec.assertoutcome(passed=2, skipped=1)
|
||||||
|
|
||||||
@pytest.mark.issue308
|
def test_xfail_passing_is_xpass(self, testdir):
|
||||||
def test_xfail_is_xpass_on_individual_parametrize_instance(self, testdir):
|
|
||||||
s = """
|
s = """
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
@pytest.mark.parametrize(("input", "expected"), [
|
@pytest.mark.parametrize(("n", "expected"), [
|
||||||
(1, 2),
|
(1, 2),
|
||||||
pytest.mark.xfail("sys.version > 0", reason="some bug")((2, 3)),
|
pytest.mark.xfail("sys.version > 0", reason="some bug")((2, 3)),
|
||||||
(3, 4),
|
(3, 4),
|
||||||
])
|
])
|
||||||
def test_increment(input, expected):
|
def test_increment(n, expected):
|
||||||
assert input + 1 == expected
|
assert n + 1 == expected
|
||||||
"""
|
"""
|
||||||
testdir.makepyfile(s)
|
testdir.makepyfile(s)
|
||||||
reprec = testdir.inline_run()
|
reprec = testdir.inline_run()
|
||||||
# xpass is fail, obviously :)
|
# xpass is fail, obviously :)
|
||||||
reprec.assertoutcome(passed=2, failed=1)
|
reprec.assertoutcome(passed=2, failed=1)
|
||||||
|
|
||||||
|
def test_parametrize_called_in_generate_tests(self, testdir):
|
||||||
|
s = """
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
|
||||||
|
def pytest_generate_tests(metafunc):
|
||||||
|
passingTestData = [(1, 2),
|
||||||
|
(2, 3)]
|
||||||
|
failingTestData = [(1, 3),
|
||||||
|
(2, 2)]
|
||||||
|
|
||||||
|
testData = passingTestData + [pytest.mark.xfail(d)
|
||||||
|
for d in failingTestData]
|
||||||
|
metafunc.parametrize(("n", "expected"), testData)
|
||||||
|
|
||||||
|
|
||||||
|
def test_increment(n, expected):
|
||||||
|
assert n + 1 == expected
|
||||||
|
"""
|
||||||
|
testdir.makepyfile(s)
|
||||||
|
reprec = testdir.inline_run()
|
||||||
|
reprec.assertoutcome(passed=2, skipped=2)
|
||||||
|
|
Loading…
Reference in New Issue