From 4492322611e9adebfd0836250c93283ab7cd6bb1 Mon Sep 17 00:00:00 2001 From: eileen Date: Wed, 14 Oct 2020 14:51:04 +1300 Subject: [PATCH] dev/core#2119 Fix mailig code to exclude deleted recipients --- CRM/Mailing/BAO/Recipients.php | 35 ++++++++----------- .../phpunit/api/v3/JobProcessMailingTest.php | 17 +++++++-- 2 files changed, 30 insertions(+), 22 deletions(-) diff --git a/CRM/Mailing/BAO/Recipients.php b/CRM/Mailing/BAO/Recipients.php index 14820ed84cf1..53cf1802078d 100644 --- a/CRM/Mailing/BAO/Recipients.php +++ b/CRM/Mailing/BAO/Recipients.php @@ -57,28 +57,23 @@ public static function mailingQuery( $limitString = "LIMIT $offset, $limit"; } - $isSMSmode = CRM_Core_DAO::getFieldValue('CRM_Mailing_BAO_Mailing', $mailingID, 'sms_provider_id', 'id'); - $additionalJoin = ''; - if (!$isSMSmode) { - // mailing_recipients added when mailing is submitted in UI by user. - // if any email is marked on_hold =1 or contact is deceased after mailing is submitted - // then it should be get skipped while preparing event_queue - // event_queue list is prepared when mailing job gets started. - $additionalJoin = " INNER JOIN civicrm_email e ON (r.email_id = e.id AND e.on_hold = 0) - INNER JOIN civicrm_contact c on (c.id = r.contact_id AND c.is_deceased <> 1 AND c.do_not_email = 0 AND c.is_opt_out = 0) -"; - } - else { - $additionalJoin = "INNER JOIN civicrm_contact c on (c.id = r.contact_id AND c.is_deceased <> 1 AND c.do_not_sms = 0 AND c.is_opt_out = 0)"; - } + $isSMSMode = CRM_Core_DAO::getFieldValue('CRM_Mailing_BAO_Mailing', $mailingID, 'sms_provider_id', 'id'); + $additionalJoin = $isSMSMode ? '' : " INNER JOIN civicrm_email e ON (r.email_id = e.id AND e.on_hold = 0)"; $sql = " -SELECT r.contact_id, r.email_id, r.phone_id -FROM civicrm_mailing_recipients r -{$additionalJoin} -WHERE r.mailing_id = %1 - $limitString -"; + SELECT r.contact_id, r.email_id, r.phone_id + FROM civicrm_mailing_recipients r + INNER JOIN civicrm_contact c on + (c.id = r.contact_id + AND c.is_deleted = 0 + AND c.is_deceased = 0 + AND c.do_not_" . ($isSMSMode ? 'sms' : 'email') . " = 0 + AND c.is_opt_out = 0 + ) + {$additionalJoin} + WHERE r.mailing_id = %1 + $limitString + "; $params = [1 => [$mailingID, 'Integer']]; return CRM_Core_DAO::executeQuery($sql, $params); diff --git a/tests/phpunit/api/v3/JobProcessMailingTest.php b/tests/phpunit/api/v3/JobProcessMailingTest.php index 71d18540772e..163ef35b212b 100644 --- a/tests/phpunit/api/v3/JobProcessMailingTest.php +++ b/tests/phpunit/api/v3/JobProcessMailingTest.php @@ -16,7 +16,6 @@ * @subpackage API_Job * * @copyright CiviCRM LLC https://civicrm.org/licensing - * @version $Id: Job.php 30879 2010-11-22 15:45:55Z shot $ * */ @@ -100,10 +99,23 @@ public function testBasic() { $this->_mut->assertRecipients($this->getRecipients(1, 2)); } + /** + * Test that a contact deleted after the mailing is queued is not emailed. + * + * @throws \CRM_Core_Exception + */ + public function testDeletedRecipient() { + $this->createContactsInGroup(2, $this->_groupID); + $this->callAPISuccess('Mailing', 'create', $this->_params); + $this->callAPISuccess('Contact', 'delete', ['id' => $this->callAPISuccessGetValue('GroupContact', ['return' => 'contact_id', 'options' => ['limit' => 1, 'sort' => 'id DESC']])]); + $this->callAPISuccess('job', 'process_mailing'); + $this->_mut->assertRecipients($this->getRecipients(1, 1)); + } + /** * Test what happens when a contact is set to decesaed */ - public function testDecesasedRecepient() { + public function testDeceasedRecipient() { $contactID = $this->individualCreate(['first_name' => 'test dead recipeint', 'email' => 'mailtestdead@civicrm.org']); $this->callAPISuccess('group_contact', 'create', [ 'contact_id' => $contactID, @@ -571,6 +583,7 @@ protected function cleanupMailingTest() { 'civicrm_activity_contact', 'civicrm_activity', ]); + Civi::settings()->set('mailerBatchLimit', 0); } /**