2009-07-19 18:01:52 -03:00
|
|
|
"""
|
|
|
|
Python unit testing framework, based on Erich Gamma's JUnit and Kent Beck's
|
2016-01-15 13:53:51 -04:00
|
|
|
Smalltalk testing framework (used with permission).
|
2009-07-19 18:01:52 -03:00
|
|
|
|
|
|
|
This module contains the core framework classes that form the basis of
|
|
|
|
specific test cases and suites (TestCase, TestSuite etc.), and also a
|
|
|
|
text-based utility class for running the tests and reporting the results
|
|
|
|
(TextTestRunner).
|
|
|
|
|
|
|
|
Simple usage:
|
|
|
|
|
|
|
|
import unittest
|
|
|
|
|
2013-09-09 06:34:24 -03:00
|
|
|
class IntegerArithmeticTestCase(unittest.TestCase):
|
2016-09-28 11:28:41 -03:00
|
|
|
def testAdd(self): # test method names begin with 'test'
|
2009-07-19 18:01:52 -03:00
|
|
|
self.assertEqual((1 + 2), 3)
|
|
|
|
self.assertEqual(0 + 1, 1)
|
|
|
|
def testMultiply(self):
|
|
|
|
self.assertEqual((0 * 10), 0)
|
|
|
|
self.assertEqual((5 * 8), 40)
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|
|
|
|
|
|
|
|
Further information is available in the bundled documentation, and from
|
|
|
|
|
|
|
|
http://docs.python.org/library/unittest.html
|
|
|
|
|
|
|
|
Copyright (c) 1999-2003 Steve Purcell
|
2010-01-09 14:45:30 -04:00
|
|
|
Copyright (c) 2003-2010 Python Software Foundation
|
2009-07-19 18:01:52 -03:00
|
|
|
This module is free software, and you may redistribute it and/or modify
|
|
|
|
it under the same terms as Python itself, so long as this copyright message
|
|
|
|
and disclaimer are retained in their original form.
|
|
|
|
|
|
|
|
IN NO EVENT SHALL THE AUTHOR BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT,
|
|
|
|
SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OF
|
|
|
|
THIS CODE, EVEN IF THE AUTHOR HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
|
|
|
|
DAMAGE.
|
|
|
|
|
|
|
|
THE AUTHOR SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
|
|
|
|
PARTICULAR PURPOSE. THE CODE PROVIDED HEREUNDER IS ON AN "AS IS" BASIS,
|
|
|
|
AND THERE IS NO OBLIGATION WHATSOEVER TO PROVIDE MAINTENANCE,
|
|
|
|
SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
|
|
|
|
"""
|
|
|
|
|
2019-05-29 06:33:59 -03:00
|
|
|
__all__ = ['TestResult', 'TestCase', 'IsolatedAsyncioTestCase', 'TestSuite',
|
2009-07-19 18:01:52 -03:00
|
|
|
'TextTestRunner', 'TestLoader', 'FunctionTestCase', 'main',
|
|
|
|
'defaultTestLoader', 'SkipTest', 'skip', 'skipIf', 'skipUnless',
|
2010-03-27 10:25:41 -03:00
|
|
|
'expectedFailure', 'TextTestResult', 'installHandler',
|
2018-11-08 22:34:33 -04:00
|
|
|
'registerResult', 'removeResult', 'removeHandler',
|
|
|
|
'addModuleCleanup']
|
2009-07-19 18:01:52 -03:00
|
|
|
|
|
|
|
# Expose obsolete functions for backwards compatibility
|
|
|
|
__all__.extend(['getTestCaseNames', 'makeSuite', 'findTestCases'])
|
|
|
|
|
2010-03-21 23:53:52 -03:00
|
|
|
__unittest = True
|
2009-07-19 18:01:52 -03:00
|
|
|
|
|
|
|
from .result import TestResult
|
2018-11-08 22:34:33 -04:00
|
|
|
from .case import (addModuleCleanup, TestCase, FunctionTestCase, SkipTest, skip,
|
|
|
|
skipIf, skipUnless, expectedFailure)
|
Merged revisions 78227,78229,78288,78348,78377,78770,78774-78776,78810 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r78227 | michael.foord | 2010-02-18 14:30:09 -0600 (Thu, 18 Feb 2010) | 1 line
unittest.TestCase uses safe_repr for producing failure messages. Partial fix for issue 7956
........
r78229 | michael.foord | 2010-02-18 15:37:07 -0600 (Thu, 18 Feb 2010) | 1 line
Fix unittest.TestCase.assertDictContainsSubset so it can't die with unicode issues when constructing failure messages. Issue 7956
........
r78288 | michael.foord | 2010-02-21 08:48:59 -0600 (Sun, 21 Feb 2010) | 1 line
Silence UnicodeWarning in crazy unittest test.
........
r78348 | michael.foord | 2010-02-22 17:28:32 -0600 (Mon, 22 Feb 2010) | 1 line
Support for old TestResult object (unittest) with warnings when using unsupported features.
........
r78377 | michael.foord | 2010-02-23 11:00:53 -0600 (Tue, 23 Feb 2010) | 1 line
unittest.TestResult can now be used with the TextTestRunner. TextTestRunner compatible with old TestResult objects.
........
r78770 | michael.foord | 2010-03-07 14:22:12 -0600 (Sun, 07 Mar 2010) | 1 line
Fix for potentials errors in constructing unittest failure messages. Plus skipped test methods no longer run setUp and tearDown (Issue 8059)
........
r78774 | michael.foord | 2010-03-07 16:04:55 -0600 (Sun, 07 Mar 2010) | 1 line
Addition of setUpClass and setUpModule shared fixtures to unittest.
........
r78775 | michael.foord | 2010-03-07 17:10:36 -0600 (Sun, 07 Mar 2010) | 1 line
Fix accidental name rebinding in unittest py3k warning filtering.
........
r78776 | michael.foord | 2010-03-07 17:16:20 -0600 (Sun, 07 Mar 2010) | 1 line
Remove accidental print statement from last commit.
........
r78810 | raymond.hettinger | 2010-03-09 02:44:18 -0600 (Tue, 09 Mar 2010) | 5 lines
Improve the basic example.
* Show both the decorator and regular form for assertRaises()
* Use assertTrue() instead of assertIn() to teach useful minimal subset of the API
........
2010-03-14 12:04:17 -03:00
|
|
|
from .suite import BaseTestSuite, TestSuite
|
2009-07-19 18:01:52 -03:00
|
|
|
from .loader import (TestLoader, defaultTestLoader, makeSuite, getTestCaseNames,
|
|
|
|
findTestCases)
|
|
|
|
from .main import TestProgram, main
|
2010-02-10 11:51:42 -04:00
|
|
|
from .runner import TextTestRunner, TextTestResult
|
2010-04-25 16:53:49 -03:00
|
|
|
from .signals import installHandler, registerResult, removeResult, removeHandler
|
2020-04-25 04:04:10 -03:00
|
|
|
# IsolatedAsyncioTestCase will be imported lazily.
|
2010-02-10 11:51:42 -04:00
|
|
|
|
|
|
|
# deprecated
|
|
|
|
_TextTestResult = TextTestResult
|
2014-11-04 10:09:01 -04:00
|
|
|
|
|
|
|
# There are no tests here, so don't try to run anything discovered from
|
|
|
|
# introspecting the symbols (e.g. FunctionTestCase). Instead, all our
|
|
|
|
# tests come from within unittest.test.
|
|
|
|
def load_tests(loader, tests, pattern):
|
|
|
|
import os.path
|
|
|
|
# top level directory cached on loader instance
|
|
|
|
this_dir = os.path.dirname(__file__)
|
|
|
|
return loader.discover(start_dir=this_dir, pattern=pattern)
|
2020-04-25 04:04:10 -03:00
|
|
|
|
|
|
|
|
|
|
|
# Lazy import of IsolatedAsyncioTestCase from .async_case
|
|
|
|
# It imports asyncio, which is relatively heavy, but most tests
|
|
|
|
# do not need it.
|
|
|
|
|
|
|
|
def __dir__():
|
|
|
|
return globals().keys() | {'IsolatedAsyncioTestCase'}
|
|
|
|
|
|
|
|
def __getattr__(name):
|
|
|
|
if name == 'IsolatedAsyncioTestCase':
|
|
|
|
global IsolatedAsyncioTestCase
|
|
|
|
from .async_case import IsolatedAsyncioTestCase
|
|
|
|
return IsolatedAsyncioTestCase
|
|
|
|
raise AttributeError(f"module {__name__!r} has no attribute {name!r}")
|