address issue122 -- explode "params" into a list in fixture function decorators
This commit is contained in:
parent
5c3d692008
commit
7766526992
|
@ -64,6 +64,9 @@ Unreleased
|
|||
- fix issue380 by making --resultlog only rely on longrepr instead
|
||||
of the "reprcrash" attribute which only exists sometimes.
|
||||
|
||||
- address issue122: allow @pytest.fixture(params=iterator) by exploding
|
||||
into a list early on.
|
||||
|
||||
- fix pexpect-3.0 compatibility for pytest's own tests.
|
||||
(fixes issue386)
|
||||
|
||||
|
|
|
@ -76,7 +76,8 @@ def fixture(scope="function", params=None, autouse=False):
|
|||
# direct decoration
|
||||
return FixtureFunctionMarker(
|
||||
"function", params, autouse)(scope)
|
||||
else:
|
||||
if params is not None and not isinstance(params, (list, tuple)):
|
||||
params = list(params)
|
||||
return FixtureFunctionMarker(scope, params, autouse)
|
||||
|
||||
def yield_fixture(scope="function", params=None, autouse=False):
|
||||
|
|
|
@ -914,6 +914,34 @@ class TestFixtureUsages:
|
|||
reprec = testdir.inline_run()
|
||||
reprec.assertoutcome(passed=1)
|
||||
|
||||
def test_fixture_parametrized_with_iterator(self, testdir):
|
||||
testdir.makepyfile("""
|
||||
import pytest
|
||||
|
||||
l = []
|
||||
def f():
|
||||
yield 1
|
||||
yield 2
|
||||
dec = pytest.fixture(scope="module", params=f())
|
||||
|
||||
@dec
|
||||
def arg(request):
|
||||
return request.param
|
||||
@dec
|
||||
def arg2(request):
|
||||
return request.param
|
||||
|
||||
def test_1(arg):
|
||||
l.append(arg)
|
||||
def test_2(arg2):
|
||||
l.append(arg2*10)
|
||||
""")
|
||||
reprec = testdir.inline_run("-v")
|
||||
reprec.assertoutcome(passed=4)
|
||||
l = reprec.getcalls("pytest_runtest_call")[0].item.module.l
|
||||
assert l == [1,2, 10,20]
|
||||
|
||||
|
||||
class TestFixtureManagerParseFactories:
|
||||
def pytest_funcarg__testdir(self, request):
|
||||
testdir = request.getfuncargvalue("testdir")
|
||||
|
|
Loading…
Reference in New Issue