Merge pull request #1561 from AbdealiJK/ajk/1558_feature

unittest.UnitTestCase: Allow __test__ for methods
This commit is contained in:
Ronny Pfannschmidt 2016-05-19 10:17:28 +02:00
commit 85393d34b6
4 changed files with 21 additions and 0 deletions

View File

@ -3,6 +3,7 @@ merlinux GmbH, Germany, office at merlinux eu
Contributors include::
Abdeali JK
Abhijeet Kasurde
Anatoly Bubenkoff
Andreas Zeidler

View File

@ -3,6 +3,10 @@
**New Features**
* Support nose-style ``__test__`` attribute on methods of classes,
including unittest-style Classes. If set to False, the test will not be
collected.
* New ``doctest_namespace`` fixture for injecting names into the
namespace in which your doctests run.
Thanks `@milliams`_ for the complete PR (`#1428`_).

View File

@ -50,6 +50,8 @@ class UnitTestCase(pytest.Class):
foundsomething = False
for name in loader.getTestCaseNames(self.obj):
x = getattr(self.obj, name)
if not getattr(x, '__test__', True):
continue
funcobj = getattr(x, 'im_func', x)
transfer_markers(funcobj, cls, module)
yield TestCaseFunction(name, parent=self)

View File

@ -735,3 +735,17 @@ def test_unittest_skip_issue1169(testdir):
*SKIP*[1]*skipping due to reasons*
*1 skipped*
""")
def test_class_method_containing_test_issue1558(testdir):
testdir.makepyfile(test_foo="""
import unittest
class MyTestCase(unittest.TestCase):
def test_should_run(self):
pass
def test_should_not_run(self):
pass
test_should_not_run.__test__ = False
""")
reprec = testdir.inline_run()
reprec.assertoutcome(passed=1)