Merged revisions 79464,79471,79623,79626,79630,79632,79643,79648-79649,79679,79685,79711,79761,79774,79777,79792-79794,79877,79898-79900 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r79464 | michael.foord | 2010-03-27 07:55:19 -0500 (Sat, 27 Mar 2010) | 1 line
A fix for running unittest tests on platforms without the audioop module (e.g. jython and IronPython)
........
r79471 | michael.foord | 2010-03-27 14:10:11 -0500 (Sat, 27 Mar 2010) | 4 lines
Addition of delta keyword argument to unittest.TestCase.assertAlmostEquals and assertNotAlmostEquals
This allows the comparison of objects by specifying a maximum difference; this includes the comparing of non-numeric objects that don't support rounding.
........
r79623 | michael.foord | 2010-04-02 16:42:47 -0500 (Fri, 02 Apr 2010) | 1 line
Addition of -b command line option to unittest for buffering stdout and stderr during test runs.
........
r79626 | michael.foord | 2010-04-02 17:08:29 -0500 (Fri, 02 Apr 2010) | 1 line
TestResult stores original sys.stdout and tests no longer use sys.__stdout__ (etc) in tests for unittest -b command line option
........
r79630 | michael.foord | 2010-04-02 17:30:56 -0500 (Fri, 02 Apr 2010) | 1 line
unittest tests no longer replace the sys.stdout put in place by regrtest
........
r79632 | michael.foord | 2010-04-02 17:55:59 -0500 (Fri, 02 Apr 2010) | 1 line
Issue #8038: Addition of unittest.TestCase.assertNotRegexpMatches
........
r79643 | michael.foord | 2010-04-02 20:15:21 -0500 (Fri, 02 Apr 2010) | 1 line
Support dotted module names for test discovery paths in unittest. Issue 8038.
........
r79648 | michael.foord | 2010-04-02 21:21:39 -0500 (Fri, 02 Apr 2010) | 1 line
Cross platform unittest.TestResult newline handling when buffering stdout / stderr.
........
r79649 | michael.foord | 2010-04-02 21:33:55 -0500 (Fri, 02 Apr 2010) | 1 line
Another attempt at a fix for unittest.test.test_result for windows line endings
........
r79679 | michael.foord | 2010-04-03 09:52:18 -0500 (Sat, 03 Apr 2010) | 1 line
Adding -b command line option to the unittest usage message.
........
r79685 | michael.foord | 2010-04-03 10:20:00 -0500 (Sat, 03 Apr 2010) | 1 line
Minor tweak to unittest command line usage message
........
r79711 | michael.foord | 2010-04-03 12:03:11 -0500 (Sat, 03 Apr 2010) | 1 line
Documenting new features in unittest
........
r79761 | michael.foord | 2010-04-04 17:41:54 -0500 (Sun, 04 Apr 2010) | 1 line
unittest documentation formatting changes
........
r79774 | michael.foord | 2010-04-04 18:28:44 -0500 (Sun, 04 Apr 2010) | 1 line
Adding documentation for new unittest.main() parameters
........
r79777 | michael.foord | 2010-04-04 19:39:50 -0500 (Sun, 04 Apr 2010) | 1 line
Document signal handling functions in unittest.rst
........
r79792 | michael.foord | 2010-04-05 05:26:26 -0500 (Mon, 05 Apr 2010) | 1 line
Documentation fixes for unittest
........
r79793 | michael.foord | 2010-04-05 05:28:27 -0500 (Mon, 05 Apr 2010) | 1 line
Furterh documentation fix for unittest.rst
........
r79794 | michael.foord | 2010-04-05 05:30:14 -0500 (Mon, 05 Apr 2010) | 1 line
Further documentation fix for unittest.rst
........
r79877 | michael.foord | 2010-04-06 18:18:16 -0500 (Tue, 06 Apr 2010) | 1 line
Fix module directory finding logic for dotted paths in unittest test discovery.
........
r79898 | michael.foord | 2010-04-07 18:04:22 -0500 (Wed, 07 Apr 2010) | 1 line
unittest.result.TestResult does not create its buffers until they're used. It uses StringIO not cStringIO. Issue 8333.
........
r79899 | michael.foord | 2010-04-07 19:04:24 -0500 (Wed, 07 Apr 2010) | 1 line
Switch regrtest to use StringIO instead of cStringIO for test_multiprocessing on Windows. Issue 8333.
........
r79900 | michael.foord | 2010-04-07 23:33:20 -0500 (Wed, 07 Apr 2010) | 1 line
Correction of unittest documentation typos and omissions
........
2010-04-11 17:43:16 -03:00
|
|
|
import datetime
|
2011-01-03 19:56:12 -04:00
|
|
|
import warnings
|
2014-04-28 20:23:50 -03:00
|
|
|
import weakref
|
2010-03-27 09:34:21 -03:00
|
|
|
import unittest
|
2021-08-29 08:04:40 -03:00
|
|
|
from test.support import gc_collect
|
2011-05-06 09:01:41 -03:00
|
|
|
from itertools import product
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
|
|
|
|
class Test_Assertions(unittest.TestCase):
|
|
|
|
def test_AlmostEqual(self):
|
|
|
|
self.assertAlmostEqual(1.00000001, 1.0)
|
|
|
|
self.assertNotAlmostEqual(1.0000001, 1.0)
|
|
|
|
self.assertRaises(self.failureException,
|
|
|
|
self.assertAlmostEqual, 1.0000001, 1.0)
|
|
|
|
self.assertRaises(self.failureException,
|
|
|
|
self.assertNotAlmostEqual, 1.00000001, 1.0)
|
|
|
|
|
|
|
|
self.assertAlmostEqual(1.1, 1.0, places=0)
|
|
|
|
self.assertRaises(self.failureException,
|
|
|
|
self.assertAlmostEqual, 1.1, 1.0, places=1)
|
|
|
|
|
|
|
|
self.assertAlmostEqual(0, .1+.1j, places=0)
|
|
|
|
self.assertNotAlmostEqual(0, .1+.1j, places=1)
|
|
|
|
self.assertRaises(self.failureException,
|
|
|
|
self.assertAlmostEqual, 0, .1+.1j, places=1)
|
|
|
|
self.assertRaises(self.failureException,
|
|
|
|
self.assertNotAlmostEqual, 0, .1+.1j, places=0)
|
|
|
|
|
|
|
|
self.assertAlmostEqual(float('inf'), float('inf'))
|
|
|
|
self.assertRaises(self.failureException, self.assertNotAlmostEqual,
|
|
|
|
float('inf'), float('inf'))
|
|
|
|
|
Merged revisions 79464,79471,79623,79626,79630,79632,79643,79648-79649,79679,79685,79711,79761,79774,79777,79792-79794,79877,79898-79900 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r79464 | michael.foord | 2010-03-27 07:55:19 -0500 (Sat, 27 Mar 2010) | 1 line
A fix for running unittest tests on platforms without the audioop module (e.g. jython and IronPython)
........
r79471 | michael.foord | 2010-03-27 14:10:11 -0500 (Sat, 27 Mar 2010) | 4 lines
Addition of delta keyword argument to unittest.TestCase.assertAlmostEquals and assertNotAlmostEquals
This allows the comparison of objects by specifying a maximum difference; this includes the comparing of non-numeric objects that don't support rounding.
........
r79623 | michael.foord | 2010-04-02 16:42:47 -0500 (Fri, 02 Apr 2010) | 1 line
Addition of -b command line option to unittest for buffering stdout and stderr during test runs.
........
r79626 | michael.foord | 2010-04-02 17:08:29 -0500 (Fri, 02 Apr 2010) | 1 line
TestResult stores original sys.stdout and tests no longer use sys.__stdout__ (etc) in tests for unittest -b command line option
........
r79630 | michael.foord | 2010-04-02 17:30:56 -0500 (Fri, 02 Apr 2010) | 1 line
unittest tests no longer replace the sys.stdout put in place by regrtest
........
r79632 | michael.foord | 2010-04-02 17:55:59 -0500 (Fri, 02 Apr 2010) | 1 line
Issue #8038: Addition of unittest.TestCase.assertNotRegexpMatches
........
r79643 | michael.foord | 2010-04-02 20:15:21 -0500 (Fri, 02 Apr 2010) | 1 line
Support dotted module names for test discovery paths in unittest. Issue 8038.
........
r79648 | michael.foord | 2010-04-02 21:21:39 -0500 (Fri, 02 Apr 2010) | 1 line
Cross platform unittest.TestResult newline handling when buffering stdout / stderr.
........
r79649 | michael.foord | 2010-04-02 21:33:55 -0500 (Fri, 02 Apr 2010) | 1 line
Another attempt at a fix for unittest.test.test_result for windows line endings
........
r79679 | michael.foord | 2010-04-03 09:52:18 -0500 (Sat, 03 Apr 2010) | 1 line
Adding -b command line option to the unittest usage message.
........
r79685 | michael.foord | 2010-04-03 10:20:00 -0500 (Sat, 03 Apr 2010) | 1 line
Minor tweak to unittest command line usage message
........
r79711 | michael.foord | 2010-04-03 12:03:11 -0500 (Sat, 03 Apr 2010) | 1 line
Documenting new features in unittest
........
r79761 | michael.foord | 2010-04-04 17:41:54 -0500 (Sun, 04 Apr 2010) | 1 line
unittest documentation formatting changes
........
r79774 | michael.foord | 2010-04-04 18:28:44 -0500 (Sun, 04 Apr 2010) | 1 line
Adding documentation for new unittest.main() parameters
........
r79777 | michael.foord | 2010-04-04 19:39:50 -0500 (Sun, 04 Apr 2010) | 1 line
Document signal handling functions in unittest.rst
........
r79792 | michael.foord | 2010-04-05 05:26:26 -0500 (Mon, 05 Apr 2010) | 1 line
Documentation fixes for unittest
........
r79793 | michael.foord | 2010-04-05 05:28:27 -0500 (Mon, 05 Apr 2010) | 1 line
Furterh documentation fix for unittest.rst
........
r79794 | michael.foord | 2010-04-05 05:30:14 -0500 (Mon, 05 Apr 2010) | 1 line
Further documentation fix for unittest.rst
........
r79877 | michael.foord | 2010-04-06 18:18:16 -0500 (Tue, 06 Apr 2010) | 1 line
Fix module directory finding logic for dotted paths in unittest test discovery.
........
r79898 | michael.foord | 2010-04-07 18:04:22 -0500 (Wed, 07 Apr 2010) | 1 line
unittest.result.TestResult does not create its buffers until they're used. It uses StringIO not cStringIO. Issue 8333.
........
r79899 | michael.foord | 2010-04-07 19:04:24 -0500 (Wed, 07 Apr 2010) | 1 line
Switch regrtest to use StringIO instead of cStringIO for test_multiprocessing on Windows. Issue 8333.
........
r79900 | michael.foord | 2010-04-07 23:33:20 -0500 (Wed, 07 Apr 2010) | 1 line
Correction of unittest documentation typos and omissions
........
2010-04-11 17:43:16 -03:00
|
|
|
def test_AmostEqualWithDelta(self):
|
|
|
|
self.assertAlmostEqual(1.1, 1.0, delta=0.5)
|
|
|
|
self.assertAlmostEqual(1.0, 1.1, delta=0.5)
|
|
|
|
self.assertNotAlmostEqual(1.1, 1.0, delta=0.05)
|
|
|
|
self.assertNotAlmostEqual(1.0, 1.1, delta=0.05)
|
|
|
|
|
2013-08-11 07:04:50 -03:00
|
|
|
self.assertAlmostEqual(1.0, 1.0, delta=0.5)
|
|
|
|
self.assertRaises(self.failureException, self.assertNotAlmostEqual,
|
|
|
|
1.0, 1.0, delta=0.5)
|
|
|
|
|
Merged revisions 79464,79471,79623,79626,79630,79632,79643,79648-79649,79679,79685,79711,79761,79774,79777,79792-79794,79877,79898-79900 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r79464 | michael.foord | 2010-03-27 07:55:19 -0500 (Sat, 27 Mar 2010) | 1 line
A fix for running unittest tests on platforms without the audioop module (e.g. jython and IronPython)
........
r79471 | michael.foord | 2010-03-27 14:10:11 -0500 (Sat, 27 Mar 2010) | 4 lines
Addition of delta keyword argument to unittest.TestCase.assertAlmostEquals and assertNotAlmostEquals
This allows the comparison of objects by specifying a maximum difference; this includes the comparing of non-numeric objects that don't support rounding.
........
r79623 | michael.foord | 2010-04-02 16:42:47 -0500 (Fri, 02 Apr 2010) | 1 line
Addition of -b command line option to unittest for buffering stdout and stderr during test runs.
........
r79626 | michael.foord | 2010-04-02 17:08:29 -0500 (Fri, 02 Apr 2010) | 1 line
TestResult stores original sys.stdout and tests no longer use sys.__stdout__ (etc) in tests for unittest -b command line option
........
r79630 | michael.foord | 2010-04-02 17:30:56 -0500 (Fri, 02 Apr 2010) | 1 line
unittest tests no longer replace the sys.stdout put in place by regrtest
........
r79632 | michael.foord | 2010-04-02 17:55:59 -0500 (Fri, 02 Apr 2010) | 1 line
Issue #8038: Addition of unittest.TestCase.assertNotRegexpMatches
........
r79643 | michael.foord | 2010-04-02 20:15:21 -0500 (Fri, 02 Apr 2010) | 1 line
Support dotted module names for test discovery paths in unittest. Issue 8038.
........
r79648 | michael.foord | 2010-04-02 21:21:39 -0500 (Fri, 02 Apr 2010) | 1 line
Cross platform unittest.TestResult newline handling when buffering stdout / stderr.
........
r79649 | michael.foord | 2010-04-02 21:33:55 -0500 (Fri, 02 Apr 2010) | 1 line
Another attempt at a fix for unittest.test.test_result for windows line endings
........
r79679 | michael.foord | 2010-04-03 09:52:18 -0500 (Sat, 03 Apr 2010) | 1 line
Adding -b command line option to the unittest usage message.
........
r79685 | michael.foord | 2010-04-03 10:20:00 -0500 (Sat, 03 Apr 2010) | 1 line
Minor tweak to unittest command line usage message
........
r79711 | michael.foord | 2010-04-03 12:03:11 -0500 (Sat, 03 Apr 2010) | 1 line
Documenting new features in unittest
........
r79761 | michael.foord | 2010-04-04 17:41:54 -0500 (Sun, 04 Apr 2010) | 1 line
unittest documentation formatting changes
........
r79774 | michael.foord | 2010-04-04 18:28:44 -0500 (Sun, 04 Apr 2010) | 1 line
Adding documentation for new unittest.main() parameters
........
r79777 | michael.foord | 2010-04-04 19:39:50 -0500 (Sun, 04 Apr 2010) | 1 line
Document signal handling functions in unittest.rst
........
r79792 | michael.foord | 2010-04-05 05:26:26 -0500 (Mon, 05 Apr 2010) | 1 line
Documentation fixes for unittest
........
r79793 | michael.foord | 2010-04-05 05:28:27 -0500 (Mon, 05 Apr 2010) | 1 line
Furterh documentation fix for unittest.rst
........
r79794 | michael.foord | 2010-04-05 05:30:14 -0500 (Mon, 05 Apr 2010) | 1 line
Further documentation fix for unittest.rst
........
r79877 | michael.foord | 2010-04-06 18:18:16 -0500 (Tue, 06 Apr 2010) | 1 line
Fix module directory finding logic for dotted paths in unittest test discovery.
........
r79898 | michael.foord | 2010-04-07 18:04:22 -0500 (Wed, 07 Apr 2010) | 1 line
unittest.result.TestResult does not create its buffers until they're used. It uses StringIO not cStringIO. Issue 8333.
........
r79899 | michael.foord | 2010-04-07 19:04:24 -0500 (Wed, 07 Apr 2010) | 1 line
Switch regrtest to use StringIO instead of cStringIO for test_multiprocessing on Windows. Issue 8333.
........
r79900 | michael.foord | 2010-04-07 23:33:20 -0500 (Wed, 07 Apr 2010) | 1 line
Correction of unittest documentation typos and omissions
........
2010-04-11 17:43:16 -03:00
|
|
|
self.assertRaises(self.failureException, self.assertAlmostEqual,
|
|
|
|
1.1, 1.0, delta=0.05)
|
|
|
|
self.assertRaises(self.failureException, self.assertNotAlmostEqual,
|
|
|
|
1.1, 1.0, delta=0.5)
|
|
|
|
|
|
|
|
self.assertRaises(TypeError, self.assertAlmostEqual,
|
|
|
|
1.1, 1.0, places=2, delta=2)
|
|
|
|
self.assertRaises(TypeError, self.assertNotAlmostEqual,
|
|
|
|
1.1, 1.0, places=2, delta=2)
|
|
|
|
|
|
|
|
first = datetime.datetime.now()
|
|
|
|
second = first + datetime.timedelta(seconds=10)
|
|
|
|
self.assertAlmostEqual(first, second,
|
|
|
|
delta=datetime.timedelta(seconds=20))
|
|
|
|
self.assertNotAlmostEqual(first, second,
|
|
|
|
delta=datetime.timedelta(seconds=5))
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def test_assertRaises(self):
|
|
|
|
def _raise(e):
|
|
|
|
raise e
|
|
|
|
self.assertRaises(KeyError, _raise, KeyError)
|
|
|
|
self.assertRaises(KeyError, _raise, KeyError("key"))
|
|
|
|
try:
|
|
|
|
self.assertRaises(KeyError, lambda: None)
|
|
|
|
except self.failureException as e:
|
|
|
|
self.assertIn("KeyError not raised", str(e))
|
|
|
|
else:
|
|
|
|
self.fail("assertRaises() didn't fail")
|
|
|
|
try:
|
|
|
|
self.assertRaises(KeyError, _raise, ValueError)
|
|
|
|
except ValueError:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
self.fail("assertRaises() didn't let exception pass through")
|
|
|
|
with self.assertRaises(KeyError) as cm:
|
|
|
|
try:
|
|
|
|
raise KeyError
|
|
|
|
except Exception as e:
|
|
|
|
exc = e
|
|
|
|
raise
|
|
|
|
self.assertIs(cm.exception, exc)
|
|
|
|
|
|
|
|
with self.assertRaises(KeyError):
|
|
|
|
raise KeyError("key")
|
|
|
|
try:
|
|
|
|
with self.assertRaises(KeyError):
|
|
|
|
pass
|
|
|
|
except self.failureException as e:
|
|
|
|
self.assertIn("KeyError not raised", str(e))
|
|
|
|
else:
|
|
|
|
self.fail("assertRaises() didn't fail")
|
|
|
|
try:
|
|
|
|
with self.assertRaises(KeyError):
|
|
|
|
raise ValueError
|
|
|
|
except ValueError:
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
self.fail("assertRaises() didn't let exception pass through")
|
|
|
|
|
2014-04-28 20:23:50 -03:00
|
|
|
def test_assertRaises_frames_survival(self):
|
|
|
|
# Issue #9815: assertRaises should avoid keeping local variables
|
|
|
|
# in a traceback alive.
|
|
|
|
class A:
|
|
|
|
pass
|
|
|
|
wr = None
|
|
|
|
|
|
|
|
class Foo(unittest.TestCase):
|
|
|
|
|
|
|
|
def foo(self):
|
|
|
|
nonlocal wr
|
|
|
|
a = A()
|
|
|
|
wr = weakref.ref(a)
|
|
|
|
try:
|
2017-04-16 04:46:38 -03:00
|
|
|
raise OSError
|
|
|
|
except OSError:
|
2014-04-28 20:23:50 -03:00
|
|
|
raise ValueError
|
|
|
|
|
|
|
|
def test_functional(self):
|
|
|
|
self.assertRaises(ValueError, self.foo)
|
|
|
|
|
|
|
|
def test_with(self):
|
|
|
|
with self.assertRaises(ValueError):
|
|
|
|
self.foo()
|
|
|
|
|
|
|
|
Foo("test_functional").run()
|
2021-08-29 08:04:40 -03:00
|
|
|
gc_collect() # For PyPy or other GCs.
|
2014-04-28 20:23:50 -03:00
|
|
|
self.assertIsNone(wr())
|
|
|
|
Foo("test_with").run()
|
2021-08-29 08:04:40 -03:00
|
|
|
gc_collect() # For PyPy or other GCs.
|
2014-04-28 20:23:50 -03:00
|
|
|
self.assertIsNone(wr())
|
|
|
|
|
2010-12-09 22:32:05 -04:00
|
|
|
def testAssertNotRegex(self):
|
|
|
|
self.assertNotRegex('Ala ma kota', r'r+')
|
Merged revisions 79464,79471,79623,79626,79630,79632,79643,79648-79649,79679,79685,79711,79761,79774,79777,79792-79794,79877,79898-79900 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r79464 | michael.foord | 2010-03-27 07:55:19 -0500 (Sat, 27 Mar 2010) | 1 line
A fix for running unittest tests on platforms without the audioop module (e.g. jython and IronPython)
........
r79471 | michael.foord | 2010-03-27 14:10:11 -0500 (Sat, 27 Mar 2010) | 4 lines
Addition of delta keyword argument to unittest.TestCase.assertAlmostEquals and assertNotAlmostEquals
This allows the comparison of objects by specifying a maximum difference; this includes the comparing of non-numeric objects that don't support rounding.
........
r79623 | michael.foord | 2010-04-02 16:42:47 -0500 (Fri, 02 Apr 2010) | 1 line
Addition of -b command line option to unittest for buffering stdout and stderr during test runs.
........
r79626 | michael.foord | 2010-04-02 17:08:29 -0500 (Fri, 02 Apr 2010) | 1 line
TestResult stores original sys.stdout and tests no longer use sys.__stdout__ (etc) in tests for unittest -b command line option
........
r79630 | michael.foord | 2010-04-02 17:30:56 -0500 (Fri, 02 Apr 2010) | 1 line
unittest tests no longer replace the sys.stdout put in place by regrtest
........
r79632 | michael.foord | 2010-04-02 17:55:59 -0500 (Fri, 02 Apr 2010) | 1 line
Issue #8038: Addition of unittest.TestCase.assertNotRegexpMatches
........
r79643 | michael.foord | 2010-04-02 20:15:21 -0500 (Fri, 02 Apr 2010) | 1 line
Support dotted module names for test discovery paths in unittest. Issue 8038.
........
r79648 | michael.foord | 2010-04-02 21:21:39 -0500 (Fri, 02 Apr 2010) | 1 line
Cross platform unittest.TestResult newline handling when buffering stdout / stderr.
........
r79649 | michael.foord | 2010-04-02 21:33:55 -0500 (Fri, 02 Apr 2010) | 1 line
Another attempt at a fix for unittest.test.test_result for windows line endings
........
r79679 | michael.foord | 2010-04-03 09:52:18 -0500 (Sat, 03 Apr 2010) | 1 line
Adding -b command line option to the unittest usage message.
........
r79685 | michael.foord | 2010-04-03 10:20:00 -0500 (Sat, 03 Apr 2010) | 1 line
Minor tweak to unittest command line usage message
........
r79711 | michael.foord | 2010-04-03 12:03:11 -0500 (Sat, 03 Apr 2010) | 1 line
Documenting new features in unittest
........
r79761 | michael.foord | 2010-04-04 17:41:54 -0500 (Sun, 04 Apr 2010) | 1 line
unittest documentation formatting changes
........
r79774 | michael.foord | 2010-04-04 18:28:44 -0500 (Sun, 04 Apr 2010) | 1 line
Adding documentation for new unittest.main() parameters
........
r79777 | michael.foord | 2010-04-04 19:39:50 -0500 (Sun, 04 Apr 2010) | 1 line
Document signal handling functions in unittest.rst
........
r79792 | michael.foord | 2010-04-05 05:26:26 -0500 (Mon, 05 Apr 2010) | 1 line
Documentation fixes for unittest
........
r79793 | michael.foord | 2010-04-05 05:28:27 -0500 (Mon, 05 Apr 2010) | 1 line
Furterh documentation fix for unittest.rst
........
r79794 | michael.foord | 2010-04-05 05:30:14 -0500 (Mon, 05 Apr 2010) | 1 line
Further documentation fix for unittest.rst
........
r79877 | michael.foord | 2010-04-06 18:18:16 -0500 (Tue, 06 Apr 2010) | 1 line
Fix module directory finding logic for dotted paths in unittest test discovery.
........
r79898 | michael.foord | 2010-04-07 18:04:22 -0500 (Wed, 07 Apr 2010) | 1 line
unittest.result.TestResult does not create its buffers until they're used. It uses StringIO not cStringIO. Issue 8333.
........
r79899 | michael.foord | 2010-04-07 19:04:24 -0500 (Wed, 07 Apr 2010) | 1 line
Switch regrtest to use StringIO instead of cStringIO for test_multiprocessing on Windows. Issue 8333.
........
r79900 | michael.foord | 2010-04-07 23:33:20 -0500 (Wed, 07 Apr 2010) | 1 line
Correction of unittest documentation typos and omissions
........
2010-04-11 17:43:16 -03:00
|
|
|
try:
|
2010-12-09 22:32:05 -04:00
|
|
|
self.assertNotRegex('Ala ma kota', r'k.t', 'Message')
|
Merged revisions 79464,79471,79623,79626,79630,79632,79643,79648-79649,79679,79685,79711,79761,79774,79777,79792-79794,79877,79898-79900 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r79464 | michael.foord | 2010-03-27 07:55:19 -0500 (Sat, 27 Mar 2010) | 1 line
A fix for running unittest tests on platforms without the audioop module (e.g. jython and IronPython)
........
r79471 | michael.foord | 2010-03-27 14:10:11 -0500 (Sat, 27 Mar 2010) | 4 lines
Addition of delta keyword argument to unittest.TestCase.assertAlmostEquals and assertNotAlmostEquals
This allows the comparison of objects by specifying a maximum difference; this includes the comparing of non-numeric objects that don't support rounding.
........
r79623 | michael.foord | 2010-04-02 16:42:47 -0500 (Fri, 02 Apr 2010) | 1 line
Addition of -b command line option to unittest for buffering stdout and stderr during test runs.
........
r79626 | michael.foord | 2010-04-02 17:08:29 -0500 (Fri, 02 Apr 2010) | 1 line
TestResult stores original sys.stdout and tests no longer use sys.__stdout__ (etc) in tests for unittest -b command line option
........
r79630 | michael.foord | 2010-04-02 17:30:56 -0500 (Fri, 02 Apr 2010) | 1 line
unittest tests no longer replace the sys.stdout put in place by regrtest
........
r79632 | michael.foord | 2010-04-02 17:55:59 -0500 (Fri, 02 Apr 2010) | 1 line
Issue #8038: Addition of unittest.TestCase.assertNotRegexpMatches
........
r79643 | michael.foord | 2010-04-02 20:15:21 -0500 (Fri, 02 Apr 2010) | 1 line
Support dotted module names for test discovery paths in unittest. Issue 8038.
........
r79648 | michael.foord | 2010-04-02 21:21:39 -0500 (Fri, 02 Apr 2010) | 1 line
Cross platform unittest.TestResult newline handling when buffering stdout / stderr.
........
r79649 | michael.foord | 2010-04-02 21:33:55 -0500 (Fri, 02 Apr 2010) | 1 line
Another attempt at a fix for unittest.test.test_result for windows line endings
........
r79679 | michael.foord | 2010-04-03 09:52:18 -0500 (Sat, 03 Apr 2010) | 1 line
Adding -b command line option to the unittest usage message.
........
r79685 | michael.foord | 2010-04-03 10:20:00 -0500 (Sat, 03 Apr 2010) | 1 line
Minor tweak to unittest command line usage message
........
r79711 | michael.foord | 2010-04-03 12:03:11 -0500 (Sat, 03 Apr 2010) | 1 line
Documenting new features in unittest
........
r79761 | michael.foord | 2010-04-04 17:41:54 -0500 (Sun, 04 Apr 2010) | 1 line
unittest documentation formatting changes
........
r79774 | michael.foord | 2010-04-04 18:28:44 -0500 (Sun, 04 Apr 2010) | 1 line
Adding documentation for new unittest.main() parameters
........
r79777 | michael.foord | 2010-04-04 19:39:50 -0500 (Sun, 04 Apr 2010) | 1 line
Document signal handling functions in unittest.rst
........
r79792 | michael.foord | 2010-04-05 05:26:26 -0500 (Mon, 05 Apr 2010) | 1 line
Documentation fixes for unittest
........
r79793 | michael.foord | 2010-04-05 05:28:27 -0500 (Mon, 05 Apr 2010) | 1 line
Furterh documentation fix for unittest.rst
........
r79794 | michael.foord | 2010-04-05 05:30:14 -0500 (Mon, 05 Apr 2010) | 1 line
Further documentation fix for unittest.rst
........
r79877 | michael.foord | 2010-04-06 18:18:16 -0500 (Tue, 06 Apr 2010) | 1 line
Fix module directory finding logic for dotted paths in unittest test discovery.
........
r79898 | michael.foord | 2010-04-07 18:04:22 -0500 (Wed, 07 Apr 2010) | 1 line
unittest.result.TestResult does not create its buffers until they're used. It uses StringIO not cStringIO. Issue 8333.
........
r79899 | michael.foord | 2010-04-07 19:04:24 -0500 (Wed, 07 Apr 2010) | 1 line
Switch regrtest to use StringIO instead of cStringIO for test_multiprocessing on Windows. Issue 8333.
........
r79900 | michael.foord | 2010-04-07 23:33:20 -0500 (Wed, 07 Apr 2010) | 1 line
Correction of unittest documentation typos and omissions
........
2010-04-11 17:43:16 -03:00
|
|
|
except self.failureException as e:
|
|
|
|
self.assertIn('Message', e.args[0])
|
|
|
|
else:
|
2010-12-09 22:32:05 -04:00
|
|
|
self.fail('assertNotRegex should have failed.')
|
Merged revisions 79464,79471,79623,79626,79630,79632,79643,79648-79649,79679,79685,79711,79761,79774,79777,79792-79794,79877,79898-79900 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r79464 | michael.foord | 2010-03-27 07:55:19 -0500 (Sat, 27 Mar 2010) | 1 line
A fix for running unittest tests on platforms without the audioop module (e.g. jython and IronPython)
........
r79471 | michael.foord | 2010-03-27 14:10:11 -0500 (Sat, 27 Mar 2010) | 4 lines
Addition of delta keyword argument to unittest.TestCase.assertAlmostEquals and assertNotAlmostEquals
This allows the comparison of objects by specifying a maximum difference; this includes the comparing of non-numeric objects that don't support rounding.
........
r79623 | michael.foord | 2010-04-02 16:42:47 -0500 (Fri, 02 Apr 2010) | 1 line
Addition of -b command line option to unittest for buffering stdout and stderr during test runs.
........
r79626 | michael.foord | 2010-04-02 17:08:29 -0500 (Fri, 02 Apr 2010) | 1 line
TestResult stores original sys.stdout and tests no longer use sys.__stdout__ (etc) in tests for unittest -b command line option
........
r79630 | michael.foord | 2010-04-02 17:30:56 -0500 (Fri, 02 Apr 2010) | 1 line
unittest tests no longer replace the sys.stdout put in place by regrtest
........
r79632 | michael.foord | 2010-04-02 17:55:59 -0500 (Fri, 02 Apr 2010) | 1 line
Issue #8038: Addition of unittest.TestCase.assertNotRegexpMatches
........
r79643 | michael.foord | 2010-04-02 20:15:21 -0500 (Fri, 02 Apr 2010) | 1 line
Support dotted module names for test discovery paths in unittest. Issue 8038.
........
r79648 | michael.foord | 2010-04-02 21:21:39 -0500 (Fri, 02 Apr 2010) | 1 line
Cross platform unittest.TestResult newline handling when buffering stdout / stderr.
........
r79649 | michael.foord | 2010-04-02 21:33:55 -0500 (Fri, 02 Apr 2010) | 1 line
Another attempt at a fix for unittest.test.test_result for windows line endings
........
r79679 | michael.foord | 2010-04-03 09:52:18 -0500 (Sat, 03 Apr 2010) | 1 line
Adding -b command line option to the unittest usage message.
........
r79685 | michael.foord | 2010-04-03 10:20:00 -0500 (Sat, 03 Apr 2010) | 1 line
Minor tweak to unittest command line usage message
........
r79711 | michael.foord | 2010-04-03 12:03:11 -0500 (Sat, 03 Apr 2010) | 1 line
Documenting new features in unittest
........
r79761 | michael.foord | 2010-04-04 17:41:54 -0500 (Sun, 04 Apr 2010) | 1 line
unittest documentation formatting changes
........
r79774 | michael.foord | 2010-04-04 18:28:44 -0500 (Sun, 04 Apr 2010) | 1 line
Adding documentation for new unittest.main() parameters
........
r79777 | michael.foord | 2010-04-04 19:39:50 -0500 (Sun, 04 Apr 2010) | 1 line
Document signal handling functions in unittest.rst
........
r79792 | michael.foord | 2010-04-05 05:26:26 -0500 (Mon, 05 Apr 2010) | 1 line
Documentation fixes for unittest
........
r79793 | michael.foord | 2010-04-05 05:28:27 -0500 (Mon, 05 Apr 2010) | 1 line
Furterh documentation fix for unittest.rst
........
r79794 | michael.foord | 2010-04-05 05:30:14 -0500 (Mon, 05 Apr 2010) | 1 line
Further documentation fix for unittest.rst
........
r79877 | michael.foord | 2010-04-06 18:18:16 -0500 (Tue, 06 Apr 2010) | 1 line
Fix module directory finding logic for dotted paths in unittest test discovery.
........
r79898 | michael.foord | 2010-04-07 18:04:22 -0500 (Wed, 07 Apr 2010) | 1 line
unittest.result.TestResult does not create its buffers until they're used. It uses StringIO not cStringIO. Issue 8333.
........
r79899 | michael.foord | 2010-04-07 19:04:24 -0500 (Wed, 07 Apr 2010) | 1 line
Switch regrtest to use StringIO instead of cStringIO for test_multiprocessing on Windows. Issue 8333.
........
r79900 | michael.foord | 2010-04-07 23:33:20 -0500 (Wed, 07 Apr 2010) | 1 line
Correction of unittest documentation typos and omissions
........
2010-04-11 17:43:16 -03:00
|
|
|
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
class TestLongMessage(unittest.TestCase):
|
|
|
|
"""Test that the individual asserts honour longMessage.
|
|
|
|
This actually tests all the message behaviour for
|
|
|
|
asserts that use longMessage."""
|
|
|
|
|
|
|
|
def setUp(self):
|
|
|
|
class TestableTestFalse(unittest.TestCase):
|
|
|
|
longMessage = False
|
|
|
|
failureException = self.failureException
|
|
|
|
|
|
|
|
def testTest(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
class TestableTestTrue(unittest.TestCase):
|
|
|
|
longMessage = True
|
|
|
|
failureException = self.failureException
|
|
|
|
|
|
|
|
def testTest(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
self.testableTrue = TestableTestTrue('testTest')
|
|
|
|
self.testableFalse = TestableTestFalse('testTest')
|
|
|
|
|
|
|
|
def testDefault(self):
|
2010-12-02 20:53:09 -04:00
|
|
|
self.assertTrue(unittest.TestCase.longMessage)
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def test_formatMsg(self):
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(self.testableFalse._formatMessage(None, "foo"), "foo")
|
|
|
|
self.assertEqual(self.testableFalse._formatMessage("foo", "bar"), "foo")
|
2010-03-27 09:34:21 -03:00
|
|
|
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(self.testableTrue._formatMessage(None, "foo"), "foo")
|
|
|
|
self.assertEqual(self.testableTrue._formatMessage("foo", "bar"), "bar : foo")
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
# This blows up if _formatMessage uses string concatenation
|
|
|
|
self.testableTrue._formatMessage(object(), 'foo')
|
|
|
|
|
|
|
|
def test_formatMessage_unicode_error(self):
|
Merged revisions 79297,79310,79382,79425-79427,79450 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r79297 | florent.xicluna | 2010-03-22 18:18:18 +0100 (lun, 22 mar 2010) | 2 lines
#7668: Fix test_httpservers failure when sys.executable contains non-ASCII bytes.
........
r79310 | florent.xicluna | 2010-03-22 23:52:11 +0100 (lun, 22 mar 2010) | 2 lines
Issue #8205: Remove the "Modules" directory from sys.path when Python is running from the build directory (POSIX only).
........
r79382 | florent.xicluna | 2010-03-24 20:33:25 +0100 (mer, 24 mar 2010) | 2 lines
Skip tests which depend on multiprocessing.sharedctypes, if _ctypes is not available.
........
r79425 | florent.xicluna | 2010-03-25 21:32:07 +0100 (jeu, 25 mar 2010) | 2 lines
Syntax cleanup `== None` -> `is None`
........
r79426 | florent.xicluna | 2010-03-25 21:33:49 +0100 (jeu, 25 mar 2010) | 2 lines
#8207: Fix test_pep277 on OS X
........
r79427 | florent.xicluna | 2010-03-25 21:39:10 +0100 (jeu, 25 mar 2010) | 2 lines
Fix test_unittest and test_warnings when running "python -Werror -m test.regrtest"
........
r79450 | florent.xicluna | 2010-03-26 20:32:44 +0100 (ven, 26 mar 2010) | 2 lines
Ensure that the failed or unexpected tests are sorted before printing.
........
2010-03-27 21:25:02 -03:00
|
|
|
one = ''.join(chr(i) for i in range(255))
|
|
|
|
# this used to cause a UnicodeDecodeError constructing msg
|
|
|
|
self.testableTrue._formatMessage(one, '\uFFFD')
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def assertMessages(self, methodName, args, errors):
|
2011-05-06 09:01:41 -03:00
|
|
|
"""
|
|
|
|
Check that methodName(*args) raises the correct error messages.
|
|
|
|
errors should be a list of 4 regex that match the error when:
|
|
|
|
1) longMessage = False and no msg passed;
|
|
|
|
2) longMessage = False and msg passed;
|
|
|
|
3) longMessage = True and no msg passed;
|
|
|
|
4) longMessage = True and msg passed;
|
|
|
|
"""
|
2010-03-27 09:34:21 -03:00
|
|
|
def getMethod(i):
|
|
|
|
useTestableFalse = i < 2
|
|
|
|
if useTestableFalse:
|
|
|
|
test = self.testableFalse
|
|
|
|
else:
|
|
|
|
test = self.testableTrue
|
|
|
|
return getattr(test, methodName)
|
|
|
|
|
2010-11-30 22:32:32 -04:00
|
|
|
for i, expected_regex in enumerate(errors):
|
2010-03-27 09:34:21 -03:00
|
|
|
testMethod = getMethod(i)
|
|
|
|
kwargs = {}
|
|
|
|
withMsg = i % 2
|
|
|
|
if withMsg:
|
|
|
|
kwargs = {"msg": "oops"}
|
|
|
|
|
2010-11-30 22:32:32 -04:00
|
|
|
with self.assertRaisesRegex(self.failureException,
|
|
|
|
expected_regex=expected_regex):
|
2010-03-27 09:34:21 -03:00
|
|
|
testMethod(*args, **kwargs)
|
|
|
|
|
|
|
|
def testAssertTrue(self):
|
|
|
|
self.assertMessages('assertTrue', (False,),
|
2010-12-18 13:31:58 -04:00
|
|
|
["^False is not true$", "^oops$", "^False is not true$",
|
|
|
|
"^False is not true : oops$"])
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def testAssertFalse(self):
|
|
|
|
self.assertMessages('assertFalse', (True,),
|
2010-12-18 13:31:58 -04:00
|
|
|
["^True is not false$", "^oops$", "^True is not false$",
|
|
|
|
"^True is not false : oops$"])
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def testNotEqual(self):
|
|
|
|
self.assertMessages('assertNotEqual', (1, 1),
|
|
|
|
["^1 == 1$", "^oops$", "^1 == 1$",
|
|
|
|
"^1 == 1 : oops$"])
|
|
|
|
|
|
|
|
def testAlmostEqual(self):
|
2017-05-01 13:18:56 -03:00
|
|
|
self.assertMessages(
|
|
|
|
'assertAlmostEqual', (1, 2),
|
2017-05-10 15:13:20 -03:00
|
|
|
[r"^1 != 2 within 7 places \(1 difference\)$", "^oops$",
|
|
|
|
r"^1 != 2 within 7 places \(1 difference\)$",
|
|
|
|
r"^1 != 2 within 7 places \(1 difference\) : oops$"])
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def testNotAlmostEqual(self):
|
|
|
|
self.assertMessages('assertNotAlmostEqual', (1, 1),
|
|
|
|
["^1 == 1 within 7 places$", "^oops$",
|
|
|
|
"^1 == 1 within 7 places$", "^1 == 1 within 7 places : oops$"])
|
|
|
|
|
|
|
|
def test_baseAssertEqual(self):
|
|
|
|
self.assertMessages('_baseAssertEqual', (1, 2),
|
|
|
|
["^1 != 2$", "^oops$", "^1 != 2$", "^1 != 2 : oops$"])
|
|
|
|
|
|
|
|
def testAssertSequenceEqual(self):
|
|
|
|
# Error messages are multiline so not testing on full message
|
|
|
|
# assertTupleEqual and assertListEqual delegate to this method
|
|
|
|
self.assertMessages('assertSequenceEqual', ([], [None]),
|
2016-09-08 14:59:53 -03:00
|
|
|
[r"\+ \[None\]$", "^oops$", r"\+ \[None\]$",
|
2010-03-27 09:34:21 -03:00
|
|
|
r"\+ \[None\] : oops$"])
|
|
|
|
|
|
|
|
def testAssertSetEqual(self):
|
|
|
|
self.assertMessages('assertSetEqual', (set(), set([None])),
|
|
|
|
["None$", "^oops$", "None$",
|
|
|
|
"None : oops$"])
|
|
|
|
|
|
|
|
def testAssertIn(self):
|
|
|
|
self.assertMessages('assertIn', (None, []),
|
2016-09-08 14:59:53 -03:00
|
|
|
[r'^None not found in \[\]$', "^oops$",
|
|
|
|
r'^None not found in \[\]$',
|
|
|
|
r'^None not found in \[\] : oops$'])
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def testAssertNotIn(self):
|
|
|
|
self.assertMessages('assertNotIn', (None, [None]),
|
2016-09-08 14:59:53 -03:00
|
|
|
[r'^None unexpectedly found in \[None\]$', "^oops$",
|
|
|
|
r'^None unexpectedly found in \[None\]$',
|
|
|
|
r'^None unexpectedly found in \[None\] : oops$'])
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def testAssertDictEqual(self):
|
|
|
|
self.assertMessages('assertDictEqual', ({}, {'key': 'value'}),
|
|
|
|
[r"\+ \{'key': 'value'\}$", "^oops$",
|
2016-09-08 14:59:53 -03:00
|
|
|
r"\+ \{'key': 'value'\}$",
|
|
|
|
r"\+ \{'key': 'value'\} : oops$"])
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def testAssertMultiLineEqual(self):
|
|
|
|
self.assertMessages('assertMultiLineEqual', ("", "foo"),
|
2023-05-04 19:37:17 -03:00
|
|
|
[r"\+ foo\n$", "^oops$",
|
|
|
|
r"\+ foo\n$",
|
|
|
|
r"\+ foo\n : oops$"])
|
2010-03-27 09:34:21 -03:00
|
|
|
|
|
|
|
def testAssertLess(self):
|
|
|
|
self.assertMessages('assertLess', (2, 1),
|
|
|
|
["^2 not less than 1$", "^oops$",
|
|
|
|
"^2 not less than 1$", "^2 not less than 1 : oops$"])
|
|
|
|
|
|
|
|
def testAssertLessEqual(self):
|
|
|
|
self.assertMessages('assertLessEqual', (2, 1),
|
|
|
|
["^2 not less than or equal to 1$", "^oops$",
|
|
|
|
"^2 not less than or equal to 1$",
|
|
|
|
"^2 not less than or equal to 1 : oops$"])
|
|
|
|
|
|
|
|
def testAssertGreater(self):
|
|
|
|
self.assertMessages('assertGreater', (1, 2),
|
|
|
|
["^1 not greater than 2$", "^oops$",
|
|
|
|
"^1 not greater than 2$",
|
|
|
|
"^1 not greater than 2 : oops$"])
|
|
|
|
|
|
|
|
def testAssertGreaterEqual(self):
|
|
|
|
self.assertMessages('assertGreaterEqual', (1, 2),
|
|
|
|
["^1 not greater than or equal to 2$", "^oops$",
|
|
|
|
"^1 not greater than or equal to 2$",
|
|
|
|
"^1 not greater than or equal to 2 : oops$"])
|
|
|
|
|
|
|
|
def testAssertIsNone(self):
|
|
|
|
self.assertMessages('assertIsNone', ('not None',),
|
|
|
|
["^'not None' is not None$", "^oops$",
|
|
|
|
"^'not None' is not None$",
|
|
|
|
"^'not None' is not None : oops$"])
|
|
|
|
|
|
|
|
def testAssertIsNotNone(self):
|
|
|
|
self.assertMessages('assertIsNotNone', (None,),
|
|
|
|
["^unexpectedly None$", "^oops$",
|
|
|
|
"^unexpectedly None$",
|
|
|
|
"^unexpectedly None : oops$"])
|
|
|
|
|
|
|
|
def testAssertIs(self):
|
|
|
|
self.assertMessages('assertIs', (None, 'foo'),
|
|
|
|
["^None is not 'foo'$", "^oops$",
|
|
|
|
"^None is not 'foo'$",
|
|
|
|
"^None is not 'foo' : oops$"])
|
|
|
|
|
|
|
|
def testAssertIsNot(self):
|
|
|
|
self.assertMessages('assertIsNot', (None, None),
|
|
|
|
["^unexpectedly identical: None$", "^oops$",
|
|
|
|
"^unexpectedly identical: None$",
|
|
|
|
"^unexpectedly identical: None : oops$"])
|
2011-05-06 09:01:41 -03:00
|
|
|
|
2015-08-19 20:13:09 -03:00
|
|
|
def testAssertRegex(self):
|
|
|
|
self.assertMessages('assertRegex', ('foo', 'bar'),
|
|
|
|
["^Regex didn't match:",
|
|
|
|
"^oops$",
|
|
|
|
"^Regex didn't match:",
|
|
|
|
"^Regex didn't match: (.*) : oops$"])
|
|
|
|
|
|
|
|
def testAssertNotRegex(self):
|
|
|
|
self.assertMessages('assertNotRegex', ('foo', 'foo'),
|
|
|
|
["^Regex matched:",
|
|
|
|
"^oops$",
|
|
|
|
"^Regex matched:",
|
|
|
|
"^Regex matched: (.*) : oops$"])
|
|
|
|
|
2011-05-06 09:01:41 -03:00
|
|
|
|
|
|
|
def assertMessagesCM(self, methodName, args, func, errors):
|
|
|
|
"""
|
|
|
|
Check that the correct error messages are raised while executing:
|
|
|
|
with method(*args):
|
|
|
|
func()
|
|
|
|
*errors* should be a list of 4 regex that match the error when:
|
|
|
|
1) longMessage = False and no msg passed;
|
|
|
|
2) longMessage = False and msg passed;
|
|
|
|
3) longMessage = True and no msg passed;
|
|
|
|
4) longMessage = True and msg passed;
|
|
|
|
"""
|
|
|
|
p = product((self.testableFalse, self.testableTrue),
|
|
|
|
({}, {"msg": "oops"}))
|
|
|
|
for (cls, kwargs), err in zip(p, errors):
|
|
|
|
method = getattr(cls, methodName)
|
|
|
|
with self.assertRaisesRegex(cls.failureException, err):
|
|
|
|
with method(*args, **kwargs) as cm:
|
|
|
|
func()
|
|
|
|
|
|
|
|
def testAssertRaises(self):
|
|
|
|
self.assertMessagesCM('assertRaises', (TypeError,), lambda: None,
|
|
|
|
['^TypeError not raised$', '^oops$',
|
|
|
|
'^TypeError not raised$',
|
|
|
|
'^TypeError not raised : oops$'])
|
|
|
|
|
|
|
|
def testAssertRaisesRegex(self):
|
|
|
|
# test error not raised
|
|
|
|
self.assertMessagesCM('assertRaisesRegex', (TypeError, 'unused regex'),
|
|
|
|
lambda: None,
|
|
|
|
['^TypeError not raised$', '^oops$',
|
|
|
|
'^TypeError not raised$',
|
|
|
|
'^TypeError not raised : oops$'])
|
|
|
|
# test error raised but with wrong message
|
|
|
|
def raise_wrong_message():
|
|
|
|
raise TypeError('foo')
|
|
|
|
self.assertMessagesCM('assertRaisesRegex', (TypeError, 'regex'),
|
|
|
|
raise_wrong_message,
|
|
|
|
['^"regex" does not match "foo"$', '^oops$',
|
|
|
|
'^"regex" does not match "foo"$',
|
|
|
|
'^"regex" does not match "foo" : oops$'])
|
|
|
|
|
|
|
|
def testAssertWarns(self):
|
|
|
|
self.assertMessagesCM('assertWarns', (UserWarning,), lambda: None,
|
|
|
|
['^UserWarning not triggered$', '^oops$',
|
|
|
|
'^UserWarning not triggered$',
|
|
|
|
'^UserWarning not triggered : oops$'])
|
|
|
|
|
2024-04-03 09:19:49 -03:00
|
|
|
def test_assertNotWarns(self):
|
|
|
|
def warn_future():
|
|
|
|
warnings.warn('xyz', FutureWarning, stacklevel=2)
|
|
|
|
self.assertMessagesCM('_assertNotWarns', (FutureWarning,),
|
|
|
|
warn_future,
|
|
|
|
['^FutureWarning triggered$',
|
|
|
|
'^oops$',
|
|
|
|
'^FutureWarning triggered$',
|
|
|
|
'^FutureWarning triggered : oops$'])
|
|
|
|
|
2011-05-06 09:01:41 -03:00
|
|
|
def testAssertWarnsRegex(self):
|
|
|
|
# test error not raised
|
|
|
|
self.assertMessagesCM('assertWarnsRegex', (UserWarning, 'unused regex'),
|
|
|
|
lambda: None,
|
|
|
|
['^UserWarning not triggered$', '^oops$',
|
|
|
|
'^UserWarning not triggered$',
|
|
|
|
'^UserWarning not triggered : oops$'])
|
|
|
|
# test warning raised but with wrong message
|
|
|
|
def raise_wrong_message():
|
|
|
|
warnings.warn('foo')
|
|
|
|
self.assertMessagesCM('assertWarnsRegex', (UserWarning, 'regex'),
|
|
|
|
raise_wrong_message,
|
|
|
|
['^"regex" does not match "foo"$', '^oops$',
|
|
|
|
'^"regex" does not match "foo"$',
|
|
|
|
'^"regex" does not match "foo" : oops$'])
|
2013-09-13 18:52:46 -03:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
unittest.main()
|