First argument in pytest.mark.skip is a reason

This commit is contained in:
Michael Aquilina 2015-10-01 22:35:38 +01:00
parent 1b5aa2868d
commit 9e57954b03
2 changed files with 30 additions and 8 deletions

View File

@ -148,15 +148,24 @@ class MarkEvaluator(object):
@pytest.hookimpl(tryfirst=True) @pytest.hookimpl(tryfirst=True)
def pytest_runtest_setup(item): def pytest_runtest_setup(item):
eval_skipif = MarkEvaluator(item, 'skipif') # Check if skip or skipif are specified as pytest marks
skipif_info = item.keywords.get('skipif')
if isinstance(skipif_info, MarkInfo):
eval_skipif = MarkEvaluator(item, 'skipif')
if eval_skipif.istrue(): if eval_skipif.istrue():
item._evalskip = eval_skipif item._evalskip = eval_skipif
pytest.skip(eval_skipif.getexplanation()) pytest.skip(eval_skipif.getexplanation())
elif isinstance(item.keywords.get('skip'), MarkInfo):
eval_skip = MarkEvaluator(item, 'skip') skip_info = item.keywords.get('skip')
item._evalskip = eval_skip if isinstance(skip_info, MarkInfo):
pytest.skip(eval_skip.getexplanation()) item._evalskip = True
if 'reason' in skip_info.kwargs:
pytest.skip(skip_info.kwargs['reason'])
elif skip_info.args:
pytest.skip(skip_info.args[0])
else:
pytest.skip()
item._evalxfail = MarkEvaluator(item, 'xfail') item._evalxfail = MarkEvaluator(item, 'xfail')
check_xfail_no_run(item) check_xfail_no_run(item)

View File

@ -409,6 +409,19 @@ class TestSkip(object):
rec = testdir.inline_run() rec = testdir.inline_run()
rec.assertoutcome(skipped=1) rec.assertoutcome(skipped=1)
def test_arg_as_reason(self, testdir):
testdir.makepyfile("""
import pytest
@pytest.mark.skip('testing stuff')
def test_bar():
pass
""")
result = testdir.runpytest('-rs')
result.stdout.fnmatch_lines([
"*testing stuff*",
"*1 skipped*",
])
def test_skip_no_reason(self, testdir): def test_skip_no_reason(self, testdir):
testdir.makepyfile(""" testdir.makepyfile("""
import pytest import pytest