mirror of
https://github.com/python/cpython.git
synced 2025-08-31 05:58:33 +00:00
bpo-30190: improved error msg for assertAlmostEqual(delta=...) (#1331)
* #30190 / unittest / assertAlmostEqual(delta=...) / error msg: show the difference between the 2 numbers in case of failure * safe_repr() diff * also show difference when passing 'places' argument * refactoring * update Misc/NEWS
This commit is contained in:
parent
1374dbb694
commit
5d7a8d0c13
3 changed files with 31 additions and 18 deletions
|
@ -856,23 +856,28 @@ class TestCase(object):
|
|||
if delta is not None and places is not None:
|
||||
raise TypeError("specify delta or places not both")
|
||||
|
||||
diff = abs(first - second)
|
||||
if delta is not None:
|
||||
if abs(first - second) <= delta:
|
||||
if diff <= delta:
|
||||
return
|
||||
|
||||
standardMsg = '%s != %s within %s delta' % (safe_repr(first),
|
||||
safe_repr(second),
|
||||
safe_repr(delta))
|
||||
standardMsg = '%s != %s within %s delta (%s difference)' % (
|
||||
safe_repr(first),
|
||||
safe_repr(second),
|
||||
safe_repr(delta),
|
||||
safe_repr(diff))
|
||||
else:
|
||||
if places is None:
|
||||
places = 7
|
||||
|
||||
if round(abs(second-first), places) == 0:
|
||||
if round(diff, places) == 0:
|
||||
return
|
||||
|
||||
standardMsg = '%s != %s within %r places' % (safe_repr(first),
|
||||
safe_repr(second),
|
||||
places)
|
||||
standardMsg = '%s != %s within %r places (%s difference)' % (
|
||||
safe_repr(first),
|
||||
safe_repr(second),
|
||||
places,
|
||||
safe_repr(diff))
|
||||
msg = self._formatMessage(msg, standardMsg)
|
||||
raise self.failureException(msg)
|
||||
|
||||
|
@ -890,16 +895,19 @@ class TestCase(object):
|
|||
"""
|
||||
if delta is not None and places is not None:
|
||||
raise TypeError("specify delta or places not both")
|
||||
diff = abs(first - second)
|
||||
if delta is not None:
|
||||
if not (first == second) and abs(first - second) > delta:
|
||||
if not (first == second) and diff > delta:
|
||||
return
|
||||
standardMsg = '%s == %s within %s delta' % (safe_repr(first),
|
||||
safe_repr(second),
|
||||
safe_repr(delta))
|
||||
standardMsg = '%s == %s within %s delta (%s difference)' % (
|
||||
safe_repr(first),
|
||||
safe_repr(second),
|
||||
safe_repr(delta),
|
||||
safe_repr(diff))
|
||||
else:
|
||||
if places is None:
|
||||
places = 7
|
||||
if not (first == second) and round(abs(second-first), places) != 0:
|
||||
if not (first == second) and round(diff, places) != 0:
|
||||
return
|
||||
standardMsg = '%s == %s within %r places' % (safe_repr(first),
|
||||
safe_repr(second),
|
||||
|
@ -908,7 +916,6 @@ class TestCase(object):
|
|||
msg = self._formatMessage(msg, standardMsg)
|
||||
raise self.failureException(msg)
|
||||
|
||||
|
||||
def assertSequenceEqual(self, seq1, seq2, msg=None, seq_type=None):
|
||||
"""An equality assertion for ordered sequences (like lists and tuples).
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue