Commit 1bcf08a8 authored by Vitja Makarov's avatar Vitja Makarov

test runner: Add CythonPyregrTestCase

parent fe9bba05
...@@ -190,7 +190,9 @@ class TestBuilder(object): ...@@ -190,7 +190,9 @@ class TestBuilder(object):
if self.exclude_selectors: if self.exclude_selectors:
if [1 for match in self.exclude_selectors if match(fqmodule)]: if [1 for match in self.exclude_selectors if match(fqmodule)]:
continue continue
if context in TEST_RUN_DIRS: if context == 'pyregr':
test_class = CythonPyregrTestCase
elif context in TEST_RUN_DIRS:
if module.startswith("test_"): if module.startswith("test_"):
test_class = CythonUnitTestCase test_class = CythonUnitTestCase
else: else:
...@@ -463,8 +465,7 @@ class CythonRunTestCase(CythonCompileTestCase): ...@@ -463,8 +465,7 @@ class CythonRunTestCase(CythonCompileTestCase):
self.setUp() self.setUp()
try: try:
self.runCompileTest() self.runCompileTest()
if not self.cython_only: self.run_tests(result)
self.run_doctests(self.module, result)
finally: finally:
check_thread_termination() check_thread_termination()
except Exception: except Exception:
...@@ -475,6 +476,10 @@ class CythonRunTestCase(CythonCompileTestCase): ...@@ -475,6 +476,10 @@ class CythonRunTestCase(CythonCompileTestCase):
except Exception: except Exception:
pass pass
def run_tests(self, result):
if not self.cython_only:
self.run_doctests(self.module, result)
def run_doctests(self, module_name, result): def run_doctests(self, module_name, result):
if sys.version_info[0] >= 3 or not hasattr(os, 'fork') or not self.fork: if sys.version_info[0] >= 3 or not hasattr(os, 'fork') or not self.fork:
doctest.DocTestSuite(module_name).run(result) doctest.DocTestSuite(module_name).run(result)
...@@ -622,28 +627,53 @@ class PartialTestResult(_TextTestResult): ...@@ -622,28 +627,53 @@ class PartialTestResult(_TextTestResult):
self.write("%s\n" % line) self.write("%s\n" % line)
class CythonUnitTestCase(CythonCompileTestCase): class CythonUnitTestCase(CythonRunTestCase):
def shortDescription(self): def shortDescription(self):
return "compiling (%s) tests in %s" % (self.language, self.module) return "compiling (%s) tests in %s" % (self.language, self.module)
def run(self, result=None): def run_tests(self, result):
if result is None: unittest.defaultTestLoader.loadTestsFromName(self.module).run(result)
result = self.defaultTestResult()
result.startTest(self)
try: class CythonPyregrTestCase(CythonRunTestCase):
self.setUp() def _run_unittest(self, result, *classes):
try: """Run tests from unittest.TestCase-derived classes."""
self.runCompileTest() valid_types = (unittest.TestSuite, unittest.TestCase)
unittest.defaultTestLoader.loadTestsFromName(self.module).run(result) suite = unittest.TestSuite()
finally: for cls in classes:
check_thread_termination() if isinstance(cls, str):
except Exception: if cls in sys.modules:
result.addError(self, sys.exc_info()) suite.addTest(unittest.findTestCases(sys.modules[cls]))
result.stopTest(self) else:
raise ValueError("str arguments must be keys in sys.modules")
elif isinstance(cls, valid_types):
suite.addTest(cls)
else:
suite.addTest(unittest.makeSuite(cls))
suite.run(result)
def _run_doctest(self, result, module):
self.run_doctests(module, result)
def patch_support(self, result):
try: try:
self.tearDown() from test import test_support as support
except Exception: except ImportError: # Py3k
pass from test import support
def run_unittest(*classes):
return self._run_unittest(result, *classes)
def run_doctest(module, verbosity=None):
return self._run_doctest(result, module)
support.run_unittest = run_unittest
support.run_doctest = run_doctest
def run_tests(self, result):
self.patch_support(result)
module = __import__(self.module)
if hasattr(module, 'test_main'):
module.test_main()
try: try:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment