From bc44d94e5a29ac735be8c880e3b61990245b434d Mon Sep 17 00:00:00 2001 From: Seamus Lee Date: Wed, 17 Oct 2018 07:01:41 +1100 Subject: [PATCH 1/2] dev/core#448 Add in a Unit test to demonstrate the problem with smart groups and contats removed from smart groups not being properly checked --- tests/phpunit/CRM/Mailing/BAO/MailingTest.php | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/tests/phpunit/CRM/Mailing/BAO/MailingTest.php b/tests/phpunit/CRM/Mailing/BAO/MailingTest.php index 937babbf025f..0d00874b44f8 100644 --- a/tests/phpunit/CRM/Mailing/BAO/MailingTest.php +++ b/tests/phpunit/CRM/Mailing/BAO/MailingTest.php @@ -397,6 +397,21 @@ public function testgetRecipientsEmailGroupIncludeExclude() { unset($expected[0], $expected[4], $expected[8]); $this->assertRecipientsCorrect($mailing['id'], $expected); + // Tear down: delete mailing, groups, contacts + $this->deleteMailing($mailing['id']); + + // Create a New mailing, Testing contacts removed from smart group. + // In this case groupIDs6 will only pick up contacts[0] amd contacts[8] with it's + // criteria. However we are deliberly going to remove contactIds[8] from the group + // Which should mean the mainling only finds 1 contact that is contactIds[0] + $mailing = $this->callAPISuccess('Mailing', 'create', array()); + $this->callAPISuccess('GroupContact', 'Create', array( + 'group_id' => $groupIDs[6], + 'contact_id' => $contactIDs[8], + 'status' => 'Removed', + )); + $this->createMailingGroup($mailing['id'], $groupIDs[6]); + $this->assertRecipientsCorrect($mailing['id'], [$contactIDs[0]]); // Tear down: delete mailing, groups, contacts $this->deleteMailing($mailing['id']); foreach ($groupIDs as $groupID) { From b14b42072a7f235f97ea5901bd49dc45f992f6a5 Mon Sep 17 00:00:00 2001 From: Thomas Date: Tue, 16 Oct 2018 12:20:58 -0400 Subject: [PATCH 2/2] smart groups as mailing lists were not taking unsubscribed users into account --- CRM/Mailing/BAO/Mailing.php | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CRM/Mailing/BAO/Mailing.php b/CRM/Mailing/BAO/Mailing.php index f81bcb1d057c..aab22a064af6 100644 --- a/CRM/Mailing/BAO/Mailing.php +++ b/CRM/Mailing/BAO/Mailing.php @@ -297,9 +297,11 @@ public static function getRecipients($mailingID) { ->select("$contact.id as contact_id, $entityTable.id as $entityColumn") ->join($entityTable, " INNER JOIN $entityTable ON $entityTable.contact_id = $contact.id ") ->join('gc', " INNER JOIN civicrm_group_contact_cache gc ON $contact.id = gc.contact_id ") + ->join('gcr', " LEFT JOIN civicrm_group_contact gcr ON gc.group_id = gcr.group_id AND gc.contact_id = gcr.contact_id") ->join('mg', " INNER JOIN civicrm_mailing_group mg ON gc.group_id = mg.entity_id AND mg.search_id IS NULL ") ->join('temp', " LEFT JOIN $excludeTempTablename temp ON $contact.id = temp.contact_id ") ->where('gc.group_id IN (#groups)') + ->where('gcr.status IS NULL OR gcr.status != "Removed"') ->merge($criteria) ->replaceInto($includedTempTablename, array('contact_id', $entityColumn)) ->param('#groups', $includeSmartGroupIDs)