From dca5dce1d0e3d795329b819fb3d40d965752bb66 Mon Sep 17 00:00:00 2001 From: Patrick Peglar Date: Wed, 15 Nov 2023 12:53:04 +0000 Subject: [PATCH] Fix logic for equals expectation; expand primary/secondary independence test. --- .../unit/common/metadata/test_CubeMetadata.py | 28 +++++++++++-------- 1 file changed, 17 insertions(+), 11 deletions(-) diff --git a/lib/iris/tests/unit/common/metadata/test_CubeMetadata.py b/lib/iris/tests/unit/common/metadata/test_CubeMetadata.py index b8d9620766..7e1f64262e 100644 --- a/lib/iris/tests/unit/common/metadata/test_CubeMetadata.py +++ b/lib/iris/tests/unit/common/metadata/test_CubeMetadata.py @@ -346,12 +346,11 @@ def check_splitattrs_testcase( expected = _ALL_RESULTS[operation_name][primary_key][which] if operation_name == "equal" and expected: # Account for the equality cases made `False` by mismatched secondary values. - secondary_1, secondary_2 = secondary_inputs - if ( - secondary_1 != "X" - and secondary_2 != "X" - and secondary_1 != secondary_2 - ): + left, right = secondary_inputs + secondaries_same = left == right or ( + check_is_lenient and "X" in (left, right) + ) + if not secondaries_same: expected = False # Check that actual extracted operation result matches the "expected" one. @@ -398,7 +397,15 @@ def test_splitattrs_cases( ) @pytest.mark.parametrize( - "secondary_values", ["secondaryXX", "secondaryCC", "secondaryCD"] + "secondary_values", + [ + "secondaryXX", + "secondaryCX", + "secondaryXC", + "secondaryCC", + "secondaryCD", + ] + # NOTE: test CX as well as XC, since primary choices has "AX" but not "XA". ) def test_splitattrs_global_local_independence( self, @@ -418,10 +425,9 @@ def test_splitattrs_global_local_independence( Notes ----- We provide this *separate* test for global/local attribute independence, - parametrized over selected relevant arrangements of the 'secondary' values, and - do not test with reversed order or "local" primary inputs. - This is because matrix testing over *all* relevant factors simply produces too - many possible combinations. + parametrized over selected relevant arrangements of the 'secondary' values. + We *don't* test with reversed order or "local" primary inputs, because matrix + testing over *all* relevant factors produces too many possible combinations. """ primary_inputs = primary_values[-2:] secondary_inputs = secondary_values[-2:]