Kaydet (Commit) 2998a1c2 authored tarafından Fred Drake's avatar Fred Drake

- SF patch #1550263: Enhance and correct unittest docs

- various minor cleanups for improved consistency
üst 58af7ef5
......@@ -212,8 +212,8 @@ import unittest
class DefaultWidgetSizeTestCase(unittest.TestCase):
def runTest(self):
widget = Widget("The widget")
self.failUnless(widget.size() == (50,50), 'incorrect default size')
widget = Widget('The widget')
self.assertEqual(widget.size(), (50, 50), 'incorrect default size')
\end{verbatim}
Note that in order to test something, we use the one of the
......@@ -247,7 +247,7 @@ import unittest
class SimpleWidgetTestCase(unittest.TestCase):
def setUp(self):
self.widget = Widget("The widget")
self.widget = Widget('The widget')
class DefaultWidgetSizeTestCase(SimpleWidgetTestCase):
def runTest(self):
......@@ -273,7 +273,7 @@ import unittest
class SimpleWidgetTestCase(unittest.TestCase):
def setUp(self):
self.widget = Widget("The widget")
self.widget = Widget('The widget')
def tearDown(self):
self.widget.dispose()
......@@ -298,7 +298,7 @@ import unittest
class WidgetTestCase(unittest.TestCase):
def setUp(self):
self.widget = Widget("The widget")
self.widget = Widget('The widget')
def tearDown(self):
self.widget.dispose()
......@@ -322,8 +322,8 @@ instance we must specify the test method it is to run. We do this by
passing the method name in the constructor:
\begin{verbatim}
defaultSizeTestCase = WidgetTestCase("testDefaultSize")
resizeTestCase = WidgetTestCase("testResize")
defaultSizeTestCase = WidgetTestCase('testDefaultSize')
resizeTestCase = WidgetTestCase('testResize')
\end{verbatim}
Test case instances are grouped together according to the features
......@@ -333,8 +333,8 @@ class:
\begin{verbatim}
widgetTestSuite = unittest.TestSuite()
widgetTestSuite.addTest(WidgetTestCase("testDefaultSize"))
widgetTestSuite.addTest(WidgetTestCase("testResize"))
widgetTestSuite.addTest(WidgetTestCase('testDefaultSize'))
widgetTestSuite.addTest(WidgetTestCase('testResize'))
\end{verbatim}
For the ease of running tests, as we will see later, it is a good
......@@ -344,8 +344,8 @@ pre-built test suite:
\begin{verbatim}
def suite():
suite = unittest.TestSuite()
suite.addTest(WidgetTestCase("testDefaultSize"))
suite.addTest(WidgetTestCase("testResize"))
suite.addTest(WidgetTestCase('testDefaultSize'))
suite.addTest(WidgetTestCase('testResize'))
return suite
\end{verbatim}
......@@ -353,7 +353,7 @@ or even:
\begin{verbatim}
def suite():
tests = ["testDefaultSize", "testResize"]
tests = ['testDefaultSize', 'testResize']
return unittest.TestSuite(map(WidgetTestCase, tests))
\end{verbatim}
......@@ -462,7 +462,7 @@ easier.}
\subsection{Classes and functions
\label{unittest-contents}}
\begin{classdesc}{TestCase}{}
\begin{classdesc}{TestCase}{\optional{methodName}}
Instances of the \class{TestCase} class represent the smallest
testable units in the \module{unittest} universe. This class is
intended to be used as a base class, with specific tests being
......@@ -470,6 +470,23 @@ easier.}
interface needed by the test runner to allow it to drive the
test, and methods that the test code can use to check for and
report various kinds of failure.
Each instance of \class{TestCase} will run a single test method:
the method named \var{methodName}. If you remember, we had an
earlier example that went something like this:
\begin{verbatim}
def suite():
suite = unittest.TestSuite()
suite.addTest(WidgetTestCase('testDefaultSize'))
suite.addTest(WidgetTestCase('testResize'))
return suite
\end{verbatim}
Here, we create two instances of \class{WidgetTestCase}, each of
which runs a single test.
\var{methodName} defaults to \code{'runTest'}.
\end{classdesc}
\begin{classdesc}{FunctionTestCase}{testFunc\optional{,
......@@ -502,6 +519,11 @@ easier.}
subclass.
\end{classdesc}
\begin{classdesc}{TestResult}{}
This class is used to compile information about which tests have succeeded
and which have failed.
\end{classdesc}
\begin{datadesc}{defaultTestLoader}
Instance of the \class{TestLoader} class intended to be shared. If no
customization of the \class{TestLoader} is needed, this instance can
......@@ -574,8 +596,9 @@ Methods in the first group (running the test) are:
\begin{methoddesc}[TestCase]{run}{\optional{result}}
Run the test, collecting the result into the test result object
passed as \var{result}. If \var{result} is omitted or \constant{None},
a temporary result object is created and used, but is not made
available to the caller.
a temporary result object is created (by calling the
\method{defaultTestCase()} method) and used; this result object is not
returned to \method{run()}'s caller.
The same effect may be had by simply calling the \class{TestCase}
instance.
......@@ -684,8 +707,13 @@ information on the test:
\end{methoddesc}
\begin{methoddesc}[TestCase]{defaultTestResult}{}
Return the default type of test result object to be used to run this
test.
Return an instance of the test result class that should be used
for this test case class (if no other result instance is provided
to the \method{run()} method).
For \class{TestCase} instances, this will always be an instance of
\class{TestResult}; subclasses of \class{TestCase} should
override this as necessary.
\end{methoddesc}
\begin{methoddesc}[TestCase]{id}{}
......@@ -761,26 +789,20 @@ access to the \class{TestResult} object generated by running a set of
tests for reporting purposes; a \class{TestResult} instance is
returned by the \method{TestRunner.run()} method for this purpose.
Each instance holds the total number of tests run, and collections of
failures and errors that occurred among those test runs. The
collections contain tuples of \code{(\var{testcase},
\var{traceback})}, where \var{traceback} is a string containing a
formatted version of the traceback for the exception.
\class{TestResult} instances have the following attributes that will
be of interest when inspecting the results of running a set of tests:
\begin{memberdesc}[TestResult]{errors}
A list containing 2-tuples of \class{TestCase} instances and
formatted tracebacks. Each tuple represents a test which raised an
unexpected exception.
strings holding formatted tracebacks. Each tuple represents a test which
raised an unexpected exception.
\versionchanged[Contains formatted tracebacks instead of
\function{sys.exc_info()} results]{2.2}
\end{memberdesc}
\begin{memberdesc}[TestResult]{failures}
A list containing 2-tuples of \class{TestCase} instances and
formatted tracebacks. Each tuple represents a test where a failure
A list containing 2-tuples of \class{TestCase} instances and strings
holding formatted tracebacks. Each tuple represents a test where a failure
was explicitly signalled using the \method{TestCase.fail*()} or
\method{TestCase.assert*()} methods.
\versionchanged[Contains formatted tracebacks instead of
......@@ -817,17 +839,25 @@ reporting while tests are being run.
\begin{methoddesc}[TestResult]{startTest}{test}
Called when the test case \var{test} is about to be run.
The default implementation simply increments the instance's
\code{testsRun} counter.
\end{methoddesc}
\begin{methoddesc}[TestResult]{stopTest}{test}
Called when the test case \var{test} has been executed, regardless
Called after the test case \var{test} has been executed, regardless
of the outcome.
The default implementation does nothing.
\end{methoddesc}
\begin{methoddesc}[TestResult]{addError}{test, err}
Called when the test case \var{test} raises an unexpected exception
\var{err} is a tuple of the form returned by \function{sys.exc_info()}:
\code{(\var{type}, \var{value}, \var{traceback})}.
The default implementation appends \code{(\var{test}, \var{err})} to
the instance's \code{errors} attribute.
\end{methoddesc}
\begin{methoddesc}[TestResult]{addFailure}{test, err}
......@@ -835,10 +865,15 @@ reporting while tests are being run.
\var{err} is a tuple of the form returned by
\function{sys.exc_info()}: \code{(\var{type}, \var{value},
\var{traceback})}.
The default implementation appends \code{(\var{test}, \var{err})} to
the instance's \code{failures} attribute.
\end{methoddesc}
\begin{methoddesc}[TestResult]{addSuccess}{test}
Called when the test case \var{test} succeeds.
The default implementation does nothing.
\end{methoddesc}
......@@ -878,9 +913,12 @@ configurable properties.
Return a suite of all tests cases given a string specifier.
The specifier \var{name} is a ``dotted name'' that may resolve
either to a module, a test case class, a \class{TestSuite} instance,
a test method within a test case class, or a callable object which
returns a \class{TestCase} or \class{TestSuite} instance.
either to a module, a test case class, a test method within a test
case class, a \class{TestSuite} instance, or a callable object which
returns a \class{TestCase} or \class{TestSuite} instance. These checks
are applied in the order listed here; that is, a method on a possible
test case class will be picked up as ``a test method within a test
case class'', rather than ``a callable object''.
For example, if you have a module \module{SampleTests} containing a
\class{TestCase}-derived class \class{SampleTestCase} with three test
......@@ -905,7 +943,7 @@ configurable properties.
\begin{methoddesc}[TestLoader]{getTestCaseNames}{testCaseClass}
Return a sorted sequence of method names found within
\var{testCaseClass}.
\var{testCaseClass}; this should be a subclass of \class{TestCase}.
\end{methoddesc}
......
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