From f7519c3cc84aaa5d985cda61e02a349f126938ad Mon Sep 17 00:00:00 2001 From: Matthew Wire Date: Thu, 23 Sep 2021 13:55:15 +0100 Subject: [PATCH] Fix retrieving standardized name for billing properties --- Civi/Payment/PropertyBag.php | 7 ++++++- tests/phpunit/Civi/Payment/PropertyBagTest.php | 10 ++++++---- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/Civi/Payment/PropertyBag.php b/Civi/Payment/PropertyBag.php index f0cfa1e59a09..175abf84ed51 100644 --- a/Civi/Payment/PropertyBag.php +++ b/Civi/Payment/PropertyBag.php @@ -268,7 +268,12 @@ protected function handleLegacyPropNames($prop, $silent = FALSE) { if ($newName === NULL && substr($prop, -2) === '-' . \CRM_Core_BAO_LocationType::getBilling() && isset(static::$propMap[substr($prop, 0, -2)]) ) { - $newName = substr($prop, 0, -2); + $billingAddressProp = substr($prop, 0, -2); + $newName = static::$propMap[$billingAddressProp] ?? NULL; + if ($newName === TRUE) { + // Good, modern name. + return $billingAddressProp; + } } if ($newName === NULL) { diff --git a/tests/phpunit/Civi/Payment/PropertyBagTest.php b/tests/phpunit/Civi/Payment/PropertyBagTest.php index 38443283df26..67696aa425e3 100644 --- a/tests/phpunit/Civi/Payment/PropertyBagTest.php +++ b/tests/phpunit/Civi/Payment/PropertyBagTest.php @@ -409,9 +409,10 @@ public function testEmpty() { } /** - * * Data provider for testOtherParams + * $prop, $legacy_names, $valid_values, $invalid_values * + * return array */ public function otherParamsDataProvider() { $valid_bools = [['0' , FALSE], ['', FALSE], [0, FALSE], [FALSE, FALSE], [TRUE, TRUE], [1, TRUE], ['1', TRUE]]; @@ -420,13 +421,14 @@ public function otherParamsDataProvider() { $valid_ints = [[123, 123], ['123', 123]]; $invalid_ints = [-1, 0, NULL, '']; return [ - ['billingStreetAddress', [], $valid_strings_inc_null, []], + ['billingStreetAddress', ['billing_street_address', 'street_address', 'billing_street_address-5'], $valid_strings_inc_null, []], ['billingSupplementalAddress1', [], $valid_strings_inc_null, []], ['billingSupplementalAddress2', [], $valid_strings_inc_null, []], ['billingSupplementalAddress3', [], $valid_strings_inc_null, []], - ['billingCity', [], $valid_strings_inc_null, []], - ['billingPostalCode', [], $valid_strings_inc_null, []], + ['billingCity', ['billing_city', 'city', 'billing_city-5'], $valid_strings_inc_null, []], + ['billingPostalCode', ['billing_postal_code', 'postal_code', 'billing_postal_code-5'], $valid_strings_inc_null, []], ['billingCounty', [], $valid_strings_inc_null, []], + ['billingStateProvince', ['billing_state_province', 'state_province', 'billing_state_province-5'], $valid_strings_inc_null, []], ['billingCountry', [], [['GB', 'GB'], ['NZ', 'NZ']], ['XX', '', NULL, 0]], ['contributionID', ['contribution_id'], $valid_ints, $invalid_ints], ['contributionRecurID', ['contribution_recur_id'], $valid_ints, $invalid_ints],