Merged in hpk42/pytest-hpk/nose_test_attr (pull request #154)
support nose-style __test__ attribute to disable collection of test modules/classes/functions
This commit is contained in:
commit
080a9d2f12
|
@ -64,6 +64,10 @@ NEXT (2.6)
|
||||||
- fix issue443: fix skip examples to use proper comparison. Thanks Alex
|
- fix issue443: fix skip examples to use proper comparison. Thanks Alex
|
||||||
Groenholm.
|
Groenholm.
|
||||||
|
|
||||||
|
- support nose-style ``__test__`` attribute on modules, classes and
|
||||||
|
functions, including unittest-style Classes. If set to False, the
|
||||||
|
test will not be collected.
|
||||||
|
|
||||||
|
|
||||||
2.5.2
|
2.5.2
|
||||||
-----------------------------------
|
-----------------------------------
|
||||||
|
|
|
@ -229,10 +229,11 @@ def pytest_pycollect_makeitem(__multicall__, collector, name, obj):
|
||||||
"cannot collect %r because it is not a function."
|
"cannot collect %r because it is not a function."
|
||||||
% name, )
|
% name, )
|
||||||
return
|
return
|
||||||
if is_generator(obj):
|
if getattr(obj, "__test__", True):
|
||||||
return Generator(name, parent=collector)
|
if is_generator(obj):
|
||||||
else:
|
return Generator(name, parent=collector)
|
||||||
return list(collector._genfunctions(name, obj))
|
else:
|
||||||
|
return list(collector._genfunctions(name, obj))
|
||||||
|
|
||||||
def is_generator(func):
|
def is_generator(func):
|
||||||
try:
|
try:
|
||||||
|
@ -314,6 +315,9 @@ class PyCollector(PyobjMixin, pytest.Collector):
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def collect(self):
|
def collect(self):
|
||||||
|
if not getattr(self.obj, "__test__", True):
|
||||||
|
return []
|
||||||
|
|
||||||
# NB. we avoid random getattrs and peek in the __dict__ instead
|
# NB. we avoid random getattrs and peek in the __dict__ instead
|
||||||
# (XXX originally introduced from a PyPy need, still true?)
|
# (XXX originally introduced from a PyPy need, still true?)
|
||||||
dicts = [getattr(self.obj, '__dict__', {})]
|
dicts = [getattr(self.obj, '__dict__', {})]
|
||||||
|
|
|
@ -41,10 +41,12 @@ class UnitTestCase(pytest.Class):
|
||||||
super(UnitTestCase, self).setup()
|
super(UnitTestCase, self).setup()
|
||||||
|
|
||||||
def collect(self):
|
def collect(self):
|
||||||
|
cls = self.obj
|
||||||
|
if not getattr(cls, "__test__", True):
|
||||||
|
return
|
||||||
self.session._fixturemanager.parsefactories(self, unittest=True)
|
self.session._fixturemanager.parsefactories(self, unittest=True)
|
||||||
loader = py.std.unittest.TestLoader()
|
loader = py.std.unittest.TestLoader()
|
||||||
module = self.getparent(pytest.Module).obj
|
module = self.getparent(pytest.Module).obj
|
||||||
cls = self.obj
|
|
||||||
foundsomething = False
|
foundsomething = False
|
||||||
for name in loader.getTestCaseNames(self.obj):
|
for name in loader.getTestCaseNames(self.obj):
|
||||||
x = getattr(self.obj, name)
|
x = getattr(self.obj, name)
|
||||||
|
|
|
@ -25,6 +25,7 @@ Supported nose Idioms
|
||||||
* SkipTest exceptions and markers
|
* SkipTest exceptions and markers
|
||||||
* setup/teardown decorators
|
* setup/teardown decorators
|
||||||
* yield-based tests and their setup
|
* yield-based tests and their setup
|
||||||
|
* ``__test__`` attribute on modules/classes/functions
|
||||||
* general usage of nose utilities
|
* general usage of nose utilities
|
||||||
|
|
||||||
Unsupported idioms / known issues
|
Unsupported idioms / known issues
|
||||||
|
|
|
@ -165,6 +165,7 @@ class TestMockDecoration:
|
||||||
assert names == ["test_one", "test_two", "test_three"]
|
assert names == ["test_one", "test_two", "test_three"]
|
||||||
|
|
||||||
def test_mock_double_patch_issue473(self, testdir):
|
def test_mock_double_patch_issue473(self, testdir):
|
||||||
|
pytest.importorskip("mock", "1.0.1")
|
||||||
testdir.makepyfile("""
|
testdir.makepyfile("""
|
||||||
from mock import patch
|
from mock import patch
|
||||||
from pytest import mark
|
from pytest import mark
|
||||||
|
@ -176,8 +177,8 @@ class TestMockDecoration:
|
||||||
def test_simple_thing(self, mock_path, mock_getcwd):
|
def test_simple_thing(self, mock_path, mock_getcwd):
|
||||||
pass
|
pass
|
||||||
""")
|
""")
|
||||||
res = testdir.inline_run()
|
reprec = testdir.inline_run()
|
||||||
res.assertoutcome(passed=1)
|
reprec.assertoutcome(passed=1)
|
||||||
|
|
||||||
|
|
||||||
class TestReRunTests:
|
class TestReRunTests:
|
||||||
|
@ -214,3 +215,52 @@ class TestReRunTests:
|
||||||
def test_pytestconfig_is_session_scoped():
|
def test_pytestconfig_is_session_scoped():
|
||||||
from _pytest.python import pytestconfig
|
from _pytest.python import pytestconfig
|
||||||
assert pytestconfig._pytestfixturefunction.scope == "session"
|
assert pytestconfig._pytestfixturefunction.scope == "session"
|
||||||
|
|
||||||
|
|
||||||
|
class TestNoselikeTestAttribute:
|
||||||
|
def test_module(self, testdir):
|
||||||
|
testdir.makepyfile("""
|
||||||
|
__test__ = False
|
||||||
|
def test_hello():
|
||||||
|
pass
|
||||||
|
""")
|
||||||
|
reprec = testdir.inline_run()
|
||||||
|
assert not reprec.getfailedcollections()
|
||||||
|
calls = reprec.getreports("pytest_runtest_logreport")
|
||||||
|
assert not calls
|
||||||
|
|
||||||
|
def test_class_and_method(self, testdir):
|
||||||
|
testdir.makepyfile("""
|
||||||
|
__test__ = True
|
||||||
|
def test_func():
|
||||||
|
pass
|
||||||
|
test_func.__test__ = False
|
||||||
|
|
||||||
|
class TestSome:
|
||||||
|
__test__ = False
|
||||||
|
def test_method(self):
|
||||||
|
pass
|
||||||
|
""")
|
||||||
|
reprec = testdir.inline_run()
|
||||||
|
assert not reprec.getfailedcollections()
|
||||||
|
calls = reprec.getreports("pytest_runtest_logreport")
|
||||||
|
assert not calls
|
||||||
|
|
||||||
|
def test_unittest_class(self, testdir):
|
||||||
|
testdir.makepyfile("""
|
||||||
|
import unittest
|
||||||
|
class TC(unittest.TestCase):
|
||||||
|
def test_1(self):
|
||||||
|
pass
|
||||||
|
class TC2(unittest.TestCase):
|
||||||
|
__test__ = False
|
||||||
|
def test_2(self):
|
||||||
|
pass
|
||||||
|
""")
|
||||||
|
reprec = testdir.inline_run()
|
||||||
|
assert not reprec.getfailedcollections()
|
||||||
|
call = reprec.getcalls("pytest_collection_modifyitems")[0]
|
||||||
|
assert len(call.items) == 1
|
||||||
|
assert call.items[0].cls.__name__ == "TC"
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue