Fix error assertion handling in approx when None in dict comparison

Dict comparsion in the ApproxMapping class did not check if values were None before attempting to subtract for max_abs_diff stat, which was throwing an TypeError instead of being handled by pytest error assertion. Check for None has been added before these calculations, so that None will properly show as Obtained/Expected in pytest assert message
This commit is contained in:
Kenny Y 2023-07-07 14:42:59 -04:00
parent f5a9aa0b84
commit c5b13099e6
No known key found for this signature in database
GPG Key ID: 6048F488EF01A7F1
3 changed files with 31 additions and 12 deletions

View File

@ -0,0 +1 @@
Fixed error assertion handling in :func:`pytest.approx` when ``None`` is an expected or received value when comparing dictionaries.

View File

@ -265,6 +265,7 @@ class ApproxMapping(ApproxBase):
approx_side_as_map.items(), other_side.values() approx_side_as_map.items(), other_side.values()
): ):
if approx_value != other_value: if approx_value != other_value:
if not any((approx_value.expected is None, other_value is None)):
max_abs_diff = max( max_abs_diff = max(
max_abs_diff, abs(approx_value.expected - other_value) max_abs_diff, abs(approx_value.expected - other_value)
) )

View File

@ -122,6 +122,23 @@ class TestApprox:
], ],
) )
assert_approx_raises_regex(
{"a": 1.0, "b": None, "c": None},
{
"a": None,
"b": 1000.0,
"c": None,
},
[
r" comparison failed. Mismatched elements: 2 / 3:",
r" Max absolute difference: -inf",
r" Max relative difference: -inf",
r" Index \| Obtained\s+\| Expected\s+",
rf" a \| {SOME_FLOAT} \| None",
rf" b \| None\s+\| {SOME_FLOAT} ± {SOME_FLOAT}",
],
)
assert_approx_raises_regex( assert_approx_raises_regex(
[1.0, 2.0, 3.0, 4.0], [1.0, 2.0, 3.0, 4.0],
[1.0, 3.0, 3.0, 5.0], [1.0, 3.0, 3.0, 5.0],