summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_support.py
diff options
context:
space:
mode:
authorFred Drake <fdrake@acm.org>2001-03-21 18:26:33 (GMT)
committerFred Drake <fdrake@acm.org>2001-03-21 18:26:33 (GMT)
commitcd1b1dd6d29f81df560286f4838fefeae0af6cd8 (patch)
tree39fedb4d75bd891143600823203634d2047fcba9 /Lib/test/test_support.py
parent02538200b34c7f51852b8759f78c31da6d726964 (diff)
downloadcpython-cd1b1dd6d29f81df560286f4838fefeae0af6cd8.zip
cpython-cd1b1dd6d29f81df560286f4838fefeae0af6cd8.tar.gz
cpython-cd1b1dd6d29f81df560286f4838fefeae0af6cd8.tar.bz2
Just import sys at the top instead of inside lots of functions.
Add some helpers for supporting PyUNIT-based unit testing.
Diffstat (limited to 'Lib/test/test_support.py')
-rw-r--r--Lib/test/test_support.py38
1 files changed, 35 insertions, 3 deletions
diff --git a/Lib/test/test_support.py b/Lib/test/test_support.py
index 34b1809..ba34ac8 100644
--- a/Lib/test/test_support.py
+++ b/Lib/test/test_support.py
@@ -1,5 +1,7 @@
"""Supporting definitions for the Python regression test."""
+import sys
+
class Error(Exception):
"""Base class for regression test exceptions."""
@@ -21,7 +23,6 @@ verbose = 1 # Flag set to 0 by regrtest.py
use_large_resources = 1 # Flag set to 0 by regrtest.py
def unload(name):
- import sys
try:
del sys.modules[name]
except KeyError:
@@ -29,7 +30,7 @@ def unload(name):
def forget(modname):
unload(modname)
- import sys, os
+ import os
for dirname in sys.path:
try:
os.unlink(os.path.join(dirname, modname + '.pyc'))
@@ -68,7 +69,6 @@ def findfile(file, here=__file__):
import os
if os.path.isabs(file):
return file
- import sys
path = sys.path
path = [os.path.dirname(here)] + path
for dn in path:
@@ -93,3 +93,35 @@ def check_syntax(statement):
pass
else:
print 'Missing SyntaxError: "%s"' % statement
+
+
+
+#=======================================================================
+# Preliminary PyUNIT integration.
+
+import unittest
+
+
+class BasicTestRunner(unittest.VerboseTextTestRunner):
+ def __init__(self, stream=sys.stderr):
+ unittest.VerboseTextTestRunner.__init__(self, stream, descriptions=0)
+
+ def run(self, test):
+ result = unittest._VerboseTextTestResult(self.stream, descriptions=0)
+ test(result)
+ return result
+
+
+def run_unittest(testclass):
+ """Run tests from a unittest.TestCase-derived class."""
+ if verbose:
+ f = sys.stdout
+ else:
+ import StringIO
+ f = StringIO.StringIO()
+
+ suite = unittest.makeSuite(testclass)
+ result = BasicTestRunner(stream=f).run(suite)
+ if result.errors or result.failures:
+ raise TestFailed("errors occurred in %s.%s"
+ % (testclass.__module__, testclass.__name__))