From d4bc730a5a17d3c4ae31c37b99955a7e3bab4935 Mon Sep 17 00:00:00 2001 From: Matthew Hilton Date: Tue, 9 Jul 2024 11:15:26 +1000 Subject: [PATCH 1/2] feat: suppress cancel emails in bulk upload --- classes/booking_manager.php | 2 +- tests/upload_test.php | 21 ++++++++++++++++----- 2 files changed, 17 insertions(+), 6 deletions(-) diff --git a/classes/booking_manager.php b/classes/booking_manager.php index 9650450..af97e53 100644 --- a/classes/booking_manager.php +++ b/classes/booking_manager.php @@ -335,7 +335,7 @@ public function process() { if (facetoface_user_cancel($session, $user->id, true, $cancelerr)) { // Notify the user of the cancellation if the session hasn't started yet. $timenow = time(); - if (!facetoface_has_session_started($session, $timenow)) { + if (!facetoface_has_session_started($session, $timenow) && !$this->suppressemail) { facetoface_send_cancellation_notice($this->facetoface, $session, $user->id); } } else { diff --git a/tests/upload_test.php b/tests/upload_test.php index f071338..b7a4a83 100644 --- a/tests/upload_test.php +++ b/tests/upload_test.php @@ -550,10 +550,20 @@ public function test_updates_for_previous_sessions() { */ public static function email_suppression_provider(): array { return [ - 'no suppression' => [ + 'no suppression, booked' => [ + 'status' => 'booked', 'shouldsuppress' => false, ], - 'suppressed emails' => [ + 'suppressed emails, booked' => [ + 'status' => 'booked', + 'shouldsuppress' => true, + ], + 'no suppression, cancel' => [ + 'status' => 'cancelled', + 'shouldsuppress' => false, + ], + 'suppressed emails, cancel' => [ + 'status' => 'cancelled', 'shouldsuppress' => true, ], ]; @@ -561,10 +571,11 @@ public static function email_suppression_provider(): array { /** * Tests that the email suppression property is considered when signing up users. + * @param string $status status of session to use in csv * @param bool $shouldsuppress * @dataProvider email_suppression_provider */ - public function test_email_suppression($shouldsuppress) { + public function test_email_suppression(string $status, bool $shouldsuppress) { /** @var \mod_facetoface_generator $generator */ $generator = $this->getDataGenerator()->get_plugin_generator('mod_facetoface'); @@ -572,7 +583,7 @@ public function test_email_suppression($shouldsuppress) { // Note the f2f must have a confirmation message & subject set, otherwise no emails will be sent ever. $course = $this->getDataGenerator()->create_course(); $facetoface = $generator->create_instance(['course' => $course->id, 'confirmationmessage' => 'test', - 'confirmationsubject' => 'test']); + 'confirmationsubject' => 'test', 'cancellationmessage' => 'test', 'cancellationsubject' => 'test']); $student = $this->getDataGenerator()->create_and_enrol($course, 'student'); $this->setCurrentTimeStart(); @@ -595,7 +606,7 @@ public function test_email_suppression($shouldsuppress) { $record = (object) [ 'email' => $student->email, 'session' => $session->id, - 'status' => 'booked', + 'status' => $status, ]; $records = [$record]; From a041e71f5ecd68750e90c64a7e49b858f5f312b9 Mon Sep 17 00:00:00 2001 From: Matthew Hilton Date: Tue, 9 Jul 2024 11:24:15 +1000 Subject: [PATCH 2/2] chore: bump version --- version.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/version.php b/version.php index 7f7d2a7..9b0000a 100644 --- a/version.php +++ b/version.php @@ -30,8 +30,8 @@ defined('MOODLE_INTERNAL') || die(); -$plugin->version = 2024070500; -$plugin->release = 2024070500; +$plugin->version = 2024070900; +$plugin->release = 2024070900; $plugin->requires = 2023100900; // Requires 4.3. $plugin->component = 'mod_facetoface'; $plugin->maturity = MATURITY_STABLE;