| 
									
										
											  
											
												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 20:43:16 +00:00
										 |  |  | import datetime | 
					
						
							| 
									
										
										
										
											2011-01-03 23:56:12 +00:00
										 |  |  | import warnings | 
					
						
							| 
									
										
										
										
											2014-04-29 01:23:50 +02:00
										 |  |  | import weakref | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  | import unittest | 
					
						
							| 
									
										
										
										
											2021-08-29 14:04:40 +03:00
										 |  |  | from test.support import gc_collect | 
					
						
							| 
									
										
										
										
											2011-05-06 15:01:41 +03:00
										 |  |  | from itertools import product | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00: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 20:43:16 +00: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 13: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 20:43:16 +00: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 12:34:21 +00: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-29 01:23:50 +02: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 10:46:38 +03:00
										 |  |  |                     raise OSError | 
					
						
							|  |  |  |                 except OSError: | 
					
						
							| 
									
										
										
										
											2014-04-29 01:23:50 +02: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 14:04:40 +03:00
										 |  |  |         gc_collect()  # For PyPy or other GCs. | 
					
						
							| 
									
										
										
										
											2014-04-29 01:23:50 +02:00
										 |  |  |         self.assertIsNone(wr()) | 
					
						
							|  |  |  |         Foo("test_with").run() | 
					
						
							| 
									
										
										
										
											2021-08-29 14:04:40 +03:00
										 |  |  |         gc_collect()  # For PyPy or other GCs. | 
					
						
							| 
									
										
										
										
											2014-04-29 01:23:50 +02:00
										 |  |  |         self.assertIsNone(wr()) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-10 02:32:05 +00: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 20:43:16 +00:00
										 |  |  |         try: | 
					
						
							| 
									
										
										
										
											2010-12-10 02:32:05 +00: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 20:43:16 +00:00
										 |  |  |         except self.failureException as e: | 
					
						
							|  |  |  |             self.assertIn('Message', e.args[0]) | 
					
						
							|  |  |  |         else: | 
					
						
							| 
									
										
										
										
											2010-12-10 02:32:05 +00: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 20:43:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00: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-03 00:53:09 +00:00
										 |  |  |         self.assertTrue(unittest.TestCase.longMessage) | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def test_formatMsg(self): | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |         self.assertEqual(self.testableFalse._formatMessage(None, "foo"), "foo") | 
					
						
							|  |  |  |         self.assertEqual(self.testableFalse._formatMessage("foo", "bar"), "foo") | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-20 19:04:17 +00:00
										 |  |  |         self.assertEqual(self.testableTrue._formatMessage(None, "foo"), "foo") | 
					
						
							|  |  |  |         self.assertEqual(self.testableTrue._formatMessage("foo", "bar"), "bar : foo") | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00: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-28 00:25:02 +00: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 12:34:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def assertMessages(self, methodName, args, errors): | 
					
						
							| 
									
										
										
										
											2011-05-06 15: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 12:34:21 +00:00
										 |  |  |         def getMethod(i): | 
					
						
							|  |  |  |             useTestableFalse  = i < 2 | 
					
						
							|  |  |  |             if useTestableFalse: | 
					
						
							|  |  |  |                 test = self.testableFalse | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 test = self.testableTrue | 
					
						
							|  |  |  |             return getattr(test, methodName) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-01 02:32:32 +00:00
										 |  |  |         for i, expected_regex in enumerate(errors): | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  |             testMethod = getMethod(i) | 
					
						
							|  |  |  |             kwargs = {} | 
					
						
							|  |  |  |             withMsg = i % 2 | 
					
						
							|  |  |  |             if withMsg: | 
					
						
							|  |  |  |                 kwargs = {"msg": "oops"} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-01 02:32:32 +00:00
										 |  |  |             with self.assertRaisesRegex(self.failureException, | 
					
						
							|  |  |  |                                         expected_regex=expected_regex): | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  |                 testMethod(*args, **kwargs) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def testAssertTrue(self): | 
					
						
							|  |  |  |         self.assertMessages('assertTrue', (False,), | 
					
						
							| 
									
										
										
										
											2010-12-18 17:31:58 +00:00
										 |  |  |                             ["^False is not true$", "^oops$", "^False is not true$", | 
					
						
							|  |  |  |                              "^False is not true : oops$"]) | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def testAssertFalse(self): | 
					
						
							|  |  |  |         self.assertMessages('assertFalse', (True,), | 
					
						
							| 
									
										
										
										
											2010-12-18 17:31:58 +00:00
										 |  |  |                             ["^True is not false$", "^oops$", "^True is not false$", | 
					
						
							|  |  |  |                              "^True is not false : oops$"]) | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def testNotEqual(self): | 
					
						
							|  |  |  |         self.assertMessages('assertNotEqual', (1, 1), | 
					
						
							|  |  |  |                             ["^1 == 1$", "^oops$", "^1 == 1$", | 
					
						
							|  |  |  |                              "^1 == 1 : oops$"]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def testAlmostEqual(self): | 
					
						
							| 
									
										
										
										
											2017-05-01 18:18:56 +02:00
										 |  |  |         self.assertMessages( | 
					
						
							|  |  |  |             'assertAlmostEqual', (1, 2), | 
					
						
							| 
									
										
										
										
											2017-05-10 20:13:20 +02: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 12:34:21 +00: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 13:59:53 -04:00
										 |  |  |                             [r"\+ \[None\]$", "^oops$", r"\+ \[None\]$", | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00: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 13:59:53 -04:00
										 |  |  |                             [r'^None not found in \[\]$', "^oops$", | 
					
						
							|  |  |  |                              r'^None not found in \[\]$', | 
					
						
							|  |  |  |                              r'^None not found in \[\] : oops$']) | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def testAssertNotIn(self): | 
					
						
							|  |  |  |         self.assertMessages('assertNotIn', (None, [None]), | 
					
						
							| 
									
										
										
										
											2016-09-08 13:59:53 -04:00
										 |  |  |                             [r'^None unexpectedly found in \[None\]$', "^oops$", | 
					
						
							|  |  |  |                              r'^None unexpectedly found in \[None\]$', | 
					
						
							|  |  |  |                              r'^None unexpectedly found in \[None\] : oops$']) | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def testAssertDictEqual(self): | 
					
						
							|  |  |  |         self.assertMessages('assertDictEqual', ({}, {'key': 'value'}), | 
					
						
							|  |  |  |                             [r"\+ \{'key': 'value'\}$", "^oops$", | 
					
						
							| 
									
										
										
										
											2016-09-08 13:59:53 -04:00
										 |  |  |                              r"\+ \{'key': 'value'\}$", | 
					
						
							|  |  |  |                              r"\+ \{'key': 'value'\} : oops$"]) | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-26 20:39:15 -08:00
										 |  |  |     def testAssertDictContainsSubset(self): | 
					
						
							|  |  |  |         with warnings.catch_warnings(): | 
					
						
							|  |  |  |             warnings.simplefilter("ignore", DeprecationWarning) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             self.assertMessages('assertDictContainsSubset', ({'key': 'value'}, {}), | 
					
						
							|  |  |  |                                 ["^Missing: 'key'$", "^oops$", | 
					
						
							|  |  |  |                                  "^Missing: 'key'$", | 
					
						
							|  |  |  |                                  "^Missing: 'key' : oops$"]) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-27 12:34:21 +00:00
										 |  |  |     def testAssertMultiLineEqual(self): | 
					
						
							|  |  |  |         self.assertMessages('assertMultiLineEqual', ("", "foo"), | 
					
						
							|  |  |  |                             [r"\+ foo$", "^oops$", | 
					
						
							|  |  |  |                              r"\+ foo$", | 
					
						
							|  |  |  |                              r"\+ foo : oops$"]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     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 15:01:41 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-20 11:13:09 +12: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 15: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$']) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     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 23:52:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if __name__ == "__main__": | 
					
						
							|  |  |  |     unittest.main() |