mirror of
https://github.com/moodle/moodle.git
synced 2025-04-14 04:52:36 +02:00
MDL-47465 tool_monitor: Ignore used events
An event that has already contributed to a notification should not contribute to another notification for the same subscription. This needs to be done so we do not overwhelm the user.
This commit is contained in:
parent
1af956998e
commit
c4e3e12884
@ -129,6 +129,7 @@ class eventobservers {
|
||||
$select = "SELECT COUNT(id) FROM {tool_monitor_events} ";
|
||||
$now = time();
|
||||
$messagestosend = array();
|
||||
$allsubids = array();
|
||||
|
||||
// Let us now process the events and check for subscriptions.
|
||||
foreach ($events as $eventobj) {
|
||||
@ -136,6 +137,7 @@ class eventobservers {
|
||||
$idstosend = array();
|
||||
foreach ($subscriptions as $subscription) {
|
||||
$starttime = $now - $subscription->timewindow;
|
||||
$starttime = ($starttime > $subscription->lastnotificationsent) ? $starttime : $subscription->lastnotificationsent;
|
||||
if ($subscription->courseid == 0) {
|
||||
// Site level subscription. Count all events.
|
||||
$where = "eventname = :eventname AND timecreated > :starttime";
|
||||
@ -188,9 +190,18 @@ class eventobservers {
|
||||
}
|
||||
if (!empty($idstosend)) {
|
||||
$messagestosend[] = array('subscriptionids' => $idstosend, 'event' => $eventobj);
|
||||
$allsubids = array_merge($allsubids, $idstosend);
|
||||
}
|
||||
}
|
||||
|
||||
if (!empty($allsubids)) {
|
||||
// Update the last trigger flag.
|
||||
list($sql, $params) = $DB->get_in_or_equal($allsubids, SQL_PARAMS_NAMED);
|
||||
$params['now'] = $now;
|
||||
$sql = "UPDATE {tool_monitor_subscriptions} SET lastnotificationsent = :now WHERE id $sql";
|
||||
$DB->execute($sql, $params);
|
||||
}
|
||||
|
||||
// Schedule a task to send notification.
|
||||
if (!empty($messagestosend)) {
|
||||
$adhocktask = new notification_task();
|
||||
|
@ -266,6 +266,53 @@ class tool_monitor_eventobservers_testcase extends advanced_testcase {
|
||||
$this->verify_processed_data($msgsink);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test that same events are not used twice to calculate conditions for a single subscription.
|
||||
*/
|
||||
public function test_multiple_notification_not_sent() {
|
||||
global $USER;
|
||||
|
||||
$this->resetAfterTest();
|
||||
$this->setAdminUser();
|
||||
$messagesink = $this->redirectMessages();
|
||||
|
||||
// Generate data.
|
||||
$course = $this->getDataGenerator()->create_course();
|
||||
$toolgenerator = $this->getDataGenerator()->get_plugin_generator('tool_monitor');
|
||||
|
||||
$rulerecord = new stdClass();
|
||||
$rulerecord->courseid = $course->id;
|
||||
$rulerecord->eventname = '\mod_book\event\course_module_instance_list_viewed';
|
||||
$rulerecord->frequency = 5;
|
||||
|
||||
$rule = $toolgenerator->create_rule($rulerecord);
|
||||
|
||||
$subrecord = new stdClass();
|
||||
$subrecord->courseid = $course->id;
|
||||
$subrecord->ruleid = $rule->id;
|
||||
$subrecord->userid = $USER->id;
|
||||
$toolgenerator->create_subscription($subrecord);
|
||||
|
||||
for ($i = 0; $i < 7; $i++) {
|
||||
// Now let us trigger 7 instances of the event.
|
||||
$event = \mod_book\event\course_module_instance_list_viewed::create_from_course($course);
|
||||
$event->trigger();
|
||||
sleep(1); // Add a second delay, to prevent time collisions.
|
||||
}
|
||||
$this->run_adhock_tasks();
|
||||
$messages = $messagesink->get_messages();
|
||||
$this->assertCount(1, $messages); // There should be only one message not 3.
|
||||
for ($i = 0; $i < 3; $i++) {
|
||||
// Now let us trigger 5 more instances of the event.
|
||||
$event = \mod_book\event\course_module_instance_list_viewed::create_from_course($course);
|
||||
$event->trigger();
|
||||
}
|
||||
|
||||
$this->run_adhock_tasks();
|
||||
$messages = $messagesink->get_messages();
|
||||
$this->assertCount(2, $messages); // There should be two messages now.
|
||||
}
|
||||
|
||||
/**
|
||||
* Run adhoc tasks.
|
||||
*/
|
||||
|
Loading…
x
Reference in New Issue
Block a user