Merge pull request #1413 from nicoddemus/skip-if-parametrize

Fix skip/xfail markers in parametrized arguments
This commit is contained in:
Florian Bruhin 2016-02-26 18:41:37 +01:00
commit cbb5d48fdd
3 changed files with 88 additions and 7 deletions

View File

@ -5,7 +5,7 @@ import traceback
import py
import pytest
from _pytest.mark import MarkInfo
from _pytest.mark import MarkInfo, MarkDecorator
def pytest_addoption(parser):
@ -163,14 +163,14 @@ def pytest_runtest_setup(item):
# Check if skip or skipif are specified as pytest marks
skipif_info = item.keywords.get('skipif')
if isinstance(skipif_info, MarkInfo):
if isinstance(skipif_info, (MarkInfo, MarkDecorator)):
eval_skipif = MarkEvaluator(item, 'skipif')
if eval_skipif.istrue():
item._evalskip = eval_skipif
pytest.skip(eval_skipif.getexplanation())
skip_info = item.keywords.get('skip')
if isinstance(skip_info, MarkInfo):
if isinstance(skip_info, (MarkInfo, MarkDecorator)):
item._evalskip = True
if 'reason' in skip_info.kwargs:
pytest.skip(skip_info.kwargs['reason'])

View File

@ -531,6 +531,84 @@ class TestFunction:
assert colitems[2].name == 'test2[a-c]'
assert colitems[3].name == 'test2[b-c]'
def test_parametrize_skipif(self, testdir):
testdir.makepyfile("""
import pytest
m = pytest.mark.skipif('True')
@pytest.mark.parametrize('x', [0, 1, m(2)])
def test_skip_if(x):
assert x < 2
""")
result = testdir.runpytest()
result.stdout.fnmatch_lines('* 2 passed, 1 skipped in *')
def test_parametrize_skip(self, testdir):
testdir.makepyfile("""
import pytest
m = pytest.mark.skip('')
@pytest.mark.parametrize('x', [0, 1, m(2)])
def test_skip(x):
assert x < 2
""")
result = testdir.runpytest()
result.stdout.fnmatch_lines('* 2 passed, 1 skipped in *')
def test_parametrize_skipif_no_skip(self, testdir):
testdir.makepyfile("""
import pytest
m = pytest.mark.skipif('False')
@pytest.mark.parametrize('x', [0, 1, m(2)])
def test_skipif_no_skip(x):
assert x < 2
""")
result = testdir.runpytest()
result.stdout.fnmatch_lines('* 1 failed, 2 passed in *')
def test_parametrize_xfail(self, testdir):
testdir.makepyfile("""
import pytest
m = pytest.mark.xfail('True')
@pytest.mark.parametrize('x', [0, 1, m(2)])
def test_xfail(x):
assert x < 2
""")
result = testdir.runpytest()
result.stdout.fnmatch_lines('* 2 passed, 1 xfailed in *')
def test_parametrize_passed(self, testdir):
testdir.makepyfile("""
import pytest
m = pytest.mark.xfail('True')
@pytest.mark.parametrize('x', [0, 1, m(2)])
def test_xfail(x):
pass
""")
result = testdir.runpytest()
result.stdout.fnmatch_lines('* 2 passed, 1 xpassed in *')
def test_parametrize_xfail_passed(self, testdir):
testdir.makepyfile("""
import pytest
m = pytest.mark.xfail('False')
@pytest.mark.parametrize('x', [0, 1, m(2)])
def test_passed(x):
pass
""")
result = testdir.runpytest()
result.stdout.fnmatch_lines('* 3 passed in *')
class TestSorting:
def test_check_equality(self, testdir):

View File

@ -551,14 +551,17 @@ class TestSkipif:
pytest_runtest_setup(item))
assert x.value.msg == "condition: hasattr(os, 'sep')"
def test_skipif_reporting(self, testdir):
@pytest.mark.parametrize('params', [
'"hasattr(sys, \'platform\')"',
'True, reason="invalid platform"',
])
def test_skipif_reporting(self, testdir, params):
p = testdir.makepyfile(test_foo="""
import pytest
@pytest.mark.skipif("hasattr(sys, 'platform')")
@pytest.mark.skipif(%(params)s)
def test_that():
assert 0
""")
""" % dict(params=params))
result = testdir.runpytest(p, '-s', '-rs')
result.stdout.fnmatch_lines([
"*SKIP*1*test_foo.py*platform*",