diff --git a/CHANGELOG b/CHANGELOG index 9845ebb4c82..acd76e1b6fa 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -107,6 +107,7 @@ * SecurePayAU: Send order ID for payments with stored card [dacook] #3979 * Orbital: Add XSD version testing to unit test [almalee24] #5375 * Priority: fix for bin lookup [Buitragox] #5366 +* CommerceHub: Update merchantInvoiceNumber & merchantTransactionId [almalee24] #5374 == Version 1.137.0 (August 2, 2024) * Unlock dependency on `rexml` to allow fixing a CVE (#5181). diff --git a/lib/active_merchant/billing/gateways/commerce_hub.rb b/lib/active_merchant/billing/gateways/commerce_hub.rb index 97f979c7e8d..92ef3709961 100644 --- a/lib/active_merchant/billing/gateways/commerce_hub.rb +++ b/lib/active_merchant/billing/gateways/commerce_hub.rb @@ -154,16 +154,12 @@ def add_transaction_details(post, options, action = nil) physicalGoodsIndicator: [true, 'true'].include?(options[:physical_goods_indicator]) } - if options[:order_id].present? && action == 'sale' + if action == 'sale' details[:merchantOrderId] = options[:order_id] - details[:merchantTransactionId] = options[:order_id] + details[:merchantTransactionId] = rand.to_s[2..13] end - if action != 'capture' - details[:merchantInvoiceNumber] = options[:merchant_invoice_number] || rand.to_s[2..13] - details[:primaryTransactionType] = options[:primary_transaction_type] - details[:accountVerification] = options[:account_verification] - end + details[:merchantInvoiceNumber] = options[:order_id] if action != 'capture' post[:transactionDetails] = details.compact end diff --git a/test/remote/gateways/remote_commerce_hub_test.rb b/test/remote/gateways/remote_commerce_hub_test.rb index 5960028b831..ad6aadcb814 100644 --- a/test/remote/gateways/remote_commerce_hub_test.rb +++ b/test/remote/gateways/remote_commerce_hub_test.rb @@ -174,7 +174,7 @@ def test_successful_purchase_with_failed_avs_cvv_response_codes assert_equal 'Approved', response.message assert_equal 'X', response.cvv_result['code'] assert_equal 'CVV check not supported for card', response.cvv_result['message'] - assert_nil response.avs_result['code'] + assert_equal 'Y', response.avs_result['code'] end def test_successful_purchase_with_billing_and_shipping