Merged revisions 67985 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/trunk

........
  r67985 | antoine.pitrou | 2008-12-28 10:01:11 -0600 (Sun, 28 Dec 2008) | 4 lines

  Issue #2153: modernize coding style of unittest.py, remove obsolete compatibility stuff.
  Patch by Virgil Dupras.
........
This commit is contained in:
Benjamin Peterson 2009-01-09 03:42:38 +00:00
parent 60e9e6151f
commit 1467ac8e54
1 changed files with 19 additions and 25 deletions

View File

@ -73,7 +73,7 @@ def _strclass(cls):
__unittest = 1
class TestResult:
class TestResult(object):
"""Holder for test result information.
Test results are automatically managed by the TestCase and TestSuite
@ -149,7 +149,7 @@ def __repr__(self):
(_strclass(self.__class__), self.testsRun, len(self.errors),
len(self.failures))
class AssertRaisesContext:
class AssertRaisesContext(object):
def __init__(self, expected, test_case, callable_obj=None):
self.expected = expected
self.failureException = test_case.failureException
@ -179,7 +179,7 @@ def __exit__(self, exc_type, exc_value, traceback):
# Let unexpected exceptions skip through
return False
class TestCase:
class TestCase(object):
"""A class whose instances are single test cases.
By default, the test code itself should be placed in a method named
@ -217,8 +217,8 @@ def __init__(self, methodName='runTest'):
testMethod = getattr(self, methodName)
self._testMethodDoc = testMethod.__doc__
except AttributeError:
raise ValueError("no such test method in %s: %s"
% (self.__class__, methodName))
raise ValueError("no such test method in %s: %s" % \
(self.__class__, methodName))
def setUp(self):
"Hook method for setting up the test fixture before exercising it."
@ -273,9 +273,7 @@ def run(self, result=None):
try:
try:
self.setUp()
except KeyboardInterrupt:
raise
except:
except Exception:
result.addError(self, self._exc_info())
return
@ -285,16 +283,12 @@ def run(self, result=None):
ok = True
except self.failureException:
result.addFailure(self, self._exc_info())
except KeyboardInterrupt:
raise
except:
except Exception:
result.addError(self, self._exc_info())
try:
self.tearDown()
except KeyboardInterrupt:
raise
except:
except Exception:
result.addError(self, self._exc_info())
ok = False
if ok: result.addSuccess(self)
@ -372,8 +366,8 @@ def failUnlessAlmostEqual(self, first, second, *, places=7, msg=None):
as significant digits (measured from the most signficant digit).
"""
if round(abs(second-first), places) != 0:
raise self.failureException(msg or '%r != %r within %r places'
% (first, second, places))
raise self.failureException(
msg or '%r != %r within %r places' % (first, second, places))
def failIfAlmostEqual(self, first, second, *, places=7, msg=None):
"""Fail if the two objects are equal as determined by their
@ -384,8 +378,8 @@ def failIfAlmostEqual(self, first, second, *, places=7, msg=None):
as significant digits (measured from the most signficant digit).
"""
if round(abs(second-first), places) == 0:
raise self.failureException(msg or '%r == %r within %r places'
% (first, second, places))
raise self.failureException(
msg or '%r == %r within %r places' % (first, second, places))
# Synonyms for assertion methods
@ -405,7 +399,7 @@ def failIfAlmostEqual(self, first, second, *, places=7, msg=None):
class TestSuite:
class TestSuite(object):
"""A test suite is a composite test consisting of a number of TestCases.
For use, create an instance of TestSuite, then add test case instances.
@ -545,7 +539,7 @@ def __lt__(self, other):
return mycmp(self.obj, other.obj) == -1
return K
class TestLoader:
class TestLoader(object):
"""This class is responsible for loading tests according to various
criteria and returning them wrapped in a TestSuite
"""
@ -596,7 +590,7 @@ def loadTestsFromName(self, name, module=None):
for part in parts:
parent, obj = obj, getattr(obj, part)
if type(obj) == types.ModuleType:
if isinstance(obj, types.ModuleType):
return self.loadTestsFromModule(obj)
elif isinstance(obj, type) and issubclass(obj, TestCase):
return self.loadTestsFromTestCase(obj)
@ -672,7 +666,7 @@ def findTestCases(module, prefix='test', sortUsing=cmp, suiteClass=TestSuite):
# Text UI
##############################################################################
class _WritelnDecorator:
class _WritelnDecorator(object):
"""Used to decorate file-like objects with a handy 'writeln' method"""
def __init__(self,stream):
self.stream = stream
@ -751,7 +745,7 @@ def printErrorList(self, flavour, errors):
self.stream.writeln("%s" % err)
class TextTestRunner:
class TextTestRunner(object):
"""A test runner class that displays results in textual form.
It prints out the names of tests as they are run, errors as they
@ -797,7 +791,7 @@ def run(self, test):
# Facilities for running tests from the command line
##############################################################################
class TestProgram:
class TestProgram(object):
"""A command-line program that runs a set of tests; this is primarily
for making test modules conveniently executable.
"""
@ -819,7 +813,7 @@ class TestProgram:
def __init__(self, module='__main__', defaultTest=None,
argv=None, testRunner=TextTestRunner,
testLoader=defaultTestLoader):
if type(module) == type(''):
if isinstance(module, basestring):
self.module = __import__(module)
for part in module.split('.')[1:]:
self.module = getattr(self.module, part)