From 7ee3819f6b847a3758e70858efca8761fa1814b8 Mon Sep 17 00:00:00 2001 From: Seamus Lee Date: Wed, 26 Oct 2022 08:29:55 +1100 Subject: [PATCH] [REF] Add in Unit test to demonstrate error when trying to import a campaign id int rather than name or label of the campaign --- .../CRM/Contribute/Import/Parser/ContributionTest.php | 9 +++++++-- .../CRM/Contribute/Import/Parser/data/contributions.csv | 4 ++-- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/tests/phpunit/CRM/Contribute/Import/Parser/ContributionTest.php b/tests/phpunit/CRM/Contribute/Import/Parser/ContributionTest.php index 032aeb0cea46..6f3e0fff565c 100644 --- a/tests/phpunit/CRM/Contribute/Import/Parser/ContributionTest.php +++ b/tests/phpunit/CRM/Contribute/Import/Parser/ContributionTest.php @@ -530,6 +530,8 @@ public function validateData(): array { */ public function testImportFieldsNotRequiredWithTrxnID(): void { $this->individualCreate(['email' => 'mum@example.com']); + $this->campaignCreate(); + $this->callAPISuccess('System', 'flush', []); $fieldMappings = [ ['name' => 'first_name'], ['name' => ''], @@ -539,6 +541,7 @@ public function testImportFieldsNotRequiredWithTrxnID(): void { ['name' => ''], ['name' => ''], ['name' => 'trxn_id'], + ['name' => 'contribution_campaign_id'], ]; // First we try to create without total_amount mapped. // It will fail in create mode as total_amount is required for create. @@ -558,7 +561,7 @@ public function testImportFieldsNotRequiredWithTrxnID(): void { $this->importCSV('contributions.csv', $fieldMappings, ['onDuplicate' => CRM_Import_Parser::DUPLICATE_SKIP]); $row = $this->getDataSource()->getRows()[0]; - $this->assertEquals('IMPORTED', $row[9]); + $this->assertEquals('IMPORTED', $row[10]); $contribution = Contribution::get()->addSelect('source', 'id')->execute()->first(); $this->assertEmpty($contribution['source']); @@ -572,11 +575,13 @@ public function testImportFieldsNotRequiredWithTrxnID(): void { ['name' => ''], ['name' => 'contribution_source'], ['name' => 'trxn_id'], + ['name' => 'contribution_campaign_id'], ]; $this->importCSV('contributions.csv', $fieldMappings, ['onDuplicate' => CRM_Import_Parser::DUPLICATE_UPDATE]); $row = $this->getDataSource()->getRows()[0]; - $this->assertEquals('IMPORTED', $row[9]); + var_dump($row); + $this->assertEquals('IMPORTED', $row[10]); $contribution = Contribution::get()->addSelect('source', 'id')->execute()->first(); $this->assertEquals('Call him back', $contribution['source']); } diff --git a/tests/phpunit/CRM/Contribute/Import/Parser/data/contributions.csv b/tests/phpunit/CRM/Contribute/Import/Parser/data/contributions.csv index 46f34410b9e9..a16d213fb7ac 100644 --- a/tests/phpunit/CRM/Contribute/Import/Parser/data/contributions.csv +++ b/tests/phpunit/CRM/Contribute/Import/Parser/data/contributions.csv @@ -1,2 +1,2 @@ -External Identifier,Total Amount,Receive Date,Financial Type,Soft Credit to,Source,Note,Transaction ID -bob,65,2008-09-20,Donation,mum@example.com,Word of mouth,Call him back,999 +External Identifier,Total Amount,Receive Date,Financial Type,Soft Credit to,Source,Note,Transaction ID,Campaign ID +bob,65,2008-09-20,Donation,mum@example.com,Word of mouth,Call him back,999,1