diff options
author | Ezio Melotti <none@none> | 2011-04-27 06:45:46 (GMT) |
---|---|---|
committer | Ezio Melotti <none@none> | 2011-04-27 06:45:46 (GMT) |
commit | 34b32d62f85f198ca0c92b367e04a08febb87532 (patch) | |
tree | 938636c04083f9be5d9df818283975d90b574098 | |
parent | 5dc6868f258d71e532e2bcc2ae6a03fa9ea47016 (diff) | |
download | cpython-34b32d62f85f198ca0c92b367e04a08febb87532.zip cpython-34b32d62f85f198ca0c92b367e04a08febb87532.tar.gz cpython-34b32d62f85f198ca0c92b367e04a08febb87532.tar.bz2 |
#11763: don't use difflib in TestCase.assertMultiLineEqual if the strings are too long.
-rw-r--r-- | Lib/unittest/case.py | 8 | ||||
-rw-r--r-- | Lib/unittest/test/test_case.py | 36 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 47 insertions, 0 deletions
diff --git a/Lib/unittest/case.py b/Lib/unittest/case.py index ecb6a3e..dcaae93 100644 --- a/Lib/unittest/case.py +++ b/Lib/unittest/case.py @@ -169,6 +169,10 @@ class TestCase(object): maxDiff = 80*8 + # If a string is longer than _diffThreshold, use normal comparison instead + # of difflib. See #11763. + _diffThreshold = 2**16 + # Attribute used by TestSuite for classSetUp _classSetupFailed = False @@ -900,6 +904,10 @@ class TestCase(object): 'Second argument is not a string') if first != second: + # don't use difflib if the strings are too long + if (len(first) > self._diffThreshold or + len(second) > self._diffThreshold): + self._baseAssertEqual(first, second, msg) firstlines = first.splitlines(True) secondlines = second.splitlines(True) if len(firstlines) == 1 and first.strip('\r\n') == first: diff --git a/Lib/unittest/test/test_case.py b/Lib/unittest/test/test_case.py index 06eeda1..2e449c5 100644 --- a/Lib/unittest/test/test_case.py +++ b/Lib/unittest/test/test_case.py @@ -667,6 +667,42 @@ class Test_TestCase(unittest.TestCase, TestEquality, TestHashing): else: self.fail('assertMultiLineEqual did not fail') + def testAssertEqual_diffThreshold(self): + # check threshold value + self.assertEqual(self._diffThreshold, 2**16) + # disable madDiff to get diff markers + self.maxDiff = None + + # set a lower threshold value and add a cleanup to restore it + old_threshold = self._diffThreshold + self._diffThreshold = 2**8 + self.addCleanup(lambda: setattr(self, '_diffThreshold', old_threshold)) + + # under the threshold: diff marker (^) in error message + s = u'x' * (2**7) + with self.assertRaises(self.failureException) as cm: + self.assertEqual(s + 'a', s + 'b') + self.assertIn('^', str(cm.exception)) + self.assertEqual(s + 'a', s + 'a') + + # over the threshold: diff not used and marker (^) not in error message + s = u'x' * (2**9) + # if the path that uses difflib is taken, _truncateMessage will be + # called -- replace it with explodingTruncation to verify that this + # doesn't happen + def explodingTruncation(message, diff): + raise SystemError('this should not be raised') + old_truncate = self._truncateMessage + self._truncateMessage = explodingTruncation + self.addCleanup(lambda: setattr(self, '_truncateMessage', old_truncate)) + + s1, s2 = s + 'a', s + 'b' + with self.assertRaises(self.failureException) as cm: + self.assertEqual(s1, s2) + self.assertNotIn('^', str(cm.exception)) + self.assertEqual(str(cm.exception), '%r != %r' % (s1, s2)) + self.assertEqual(s + 'a', s + 'a') + def testAssertItemsEqual(self): a = object() self.assertItemsEqual([1, 2, 3], [3, 2, 1]) @@ -61,6 +61,9 @@ Core and Builtins Library ------- +- Issue #11763: don't use difflib in TestCase.assertMultiLineEqual if the + strings are too long. + - Issue #11236: getpass.getpass responds to ctrl-c or ctrl-z on terminal. - Issue #11768: The signal handler of the signal module only calls |