From 5f90907509865c715c14b198e14f8f4cb47bbea0 Mon Sep 17 00:00:00 2001 From: Bruno Oliveira Date: Thu, 25 Feb 2016 19:13:09 -0300 Subject: [PATCH] Fix skip/xfail markers in parametrized arguments Fix #1412 --- _pytest/skipping.py | 6 +-- testing/python/collect.py | 78 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 81 insertions(+), 3 deletions(-) diff --git a/_pytest/skipping.py b/_pytest/skipping.py index 1d2622da6..69157f485 100644 --- a/_pytest/skipping.py +++ b/_pytest/skipping.py @@ -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']) diff --git a/testing/python/collect.py b/testing/python/collect.py index 5aad619b4..7ba2574f2 100644 --- a/testing/python/collect.py +++ b/testing/python/collect.py @@ -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):