From 11829025b33c000d33e73517bf6677f8753f6faa Mon Sep 17 00:00:00 2001 From: Jake Martin White Date: Tue, 6 Oct 2015 04:38:55 +0000 Subject: [PATCH] CRM-16669 - ensure financialType is loaded for credit card and non-credit-card transactions so non_deductible amount is correctly set --- CRM/Contribute/Form/Contribution.php | 2 + .../CRM/Contribute/Form/ContributionTest.php | 50 +++++++++++++++++++ 2 files changed, 52 insertions(+) diff --git a/CRM/Contribute/Form/Contribution.php b/CRM/Contribute/Form/Contribution.php index caa9e9a22b..ea4af21068 100644 --- a/CRM/Contribute/Form/Contribution.php +++ b/CRM/Contribute/Form/Contribution.php @@ -1114,6 +1114,7 @@ class CRM_Contribute_Form_Contribution extends CRM_Contribute_Form_AbstractEditP $financialType = new CRM_Financial_DAO_FinancialType(); $financialType->id = $params['financial_type_id']; + $financialType->find(TRUE); // Add some financial type details to the params list // if folks need to use it. @@ -1768,6 +1769,7 @@ class CRM_Contribute_Form_Contribution extends CRM_Contribute_Form_AbstractEditP $financialType = new CRM_Financial_DAO_FinancialType(); $financialType->id = $params['financial_type_id']; + $financialType->find(TRUE); if ($financialType->is_deductible) { diff --git a/tests/phpunit/CRM/Contribute/Form/ContributionTest.php b/tests/phpunit/CRM/Contribute/Form/ContributionTest.php index 133af7e027..8619a958a0 100644 --- a/tests/phpunit/CRM/Contribute/Form/ContributionTest.php +++ b/tests/phpunit/CRM/Contribute/Form/ContributionTest.php @@ -291,6 +291,56 @@ class CRM_Contribute_Form_ContributionTest extends CiviUnitTestCase { $this->assertEquals('tx', $contribution['trxn_id']); } + /** + * Test a fully deductible contribution submitted by credit card (CRM-16669). + */ + public function testSubmitCreditCardFullyDeductible() { + $form = new CRM_Contribute_Form_Contribution(); + $form->_mode = 'Live'; + $form->testSubmit(array( + 'total_amount' => 50, + 'financial_type_id' => 1, + 'receive_date' => '04/21/2015', + 'receive_date_time' => '11:27PM', + 'contact_id' => $this->_individualId, + 'payment_instrument_id' => array_search('Credit Card', $this->paymentInstruments), + 'contribution_status_id' => 1, + 'credit_card_number' => 4444333322221111, + 'cvv2' => 123, + 'credit_card_exp_date' => array( + 'M' => 9, + 'Y' => 2025, + ), + 'credit_card_type' => 'Visa', + 'billing_first_name' => 'Junko', + 'billing_middle_name' => '', + 'billing_last_name' => 'Adams', + 'billing_street_address-5' => '790L Lincoln St S', + 'billing_city-5' => 'Maryknoll', + 'billing_state_province_id-5' => 1031, + 'billing_postal_code-5' => 10545, + 'billing_country_id-5' => 1228, + 'frequency_interval' => 1, + 'frequency_unit' => 'month', + 'installments' => '', + 'hidden_AdditionalDetail' => 1, + 'hidden_Premium' => 1, + 'from_email_address' => '"civi45" ', + 'receipt_date' => '', + 'receipt_date_time' => '', + 'payment_processor_id' => $this->paymentProcessorID, + 'currency' => 'USD', + 'source' => '', + ), CRM_Core_Action::ADD); + + $contribution = $this->callAPISuccessGetSingle('Contribution', array( + 'contact_id' => $this->_individualId, + 'contribution_status_id' => 'Completed', + )); + $this->assertEquals('50', $contribution['total_amount']); + $this->assertEquals(0, $contribution['non_deductible_amount']); + } + /** * Test the submit function with an invalid payment. * -- 2.25.1