MDL-44321 events: cleaning up course_module_viewed event

This commit is contained in:
Marina Glancy 2014-02-25 11:43:13 +08:00
parent 76e4de31cc
commit fbc4b77841
19 changed files with 47 additions and 102 deletions

View File

@ -96,6 +96,10 @@ abstract class course_module_viewed extends base {
if (empty($this->objectid) || empty($this->objecttable)) {
throw new \coding_exception('course_module_viewed event must define objectid and object table.');
}
// Make sure the context level is set to module.
if ($this->contextlevel != CONTEXT_MODULE) {
throw new \coding_exception('Context passed must be module context.');
}
}
}

View File

@ -80,6 +80,8 @@ if ($chapterid == '0') { // Go to first chapter if no given.
'objectid' => $book->id
);
$event = \mod_book\event\course_module_viewed::create($params);
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('book', $book);
$event->trigger();

View File

@ -81,9 +81,10 @@
$eventdata = array();
$eventdata['objectid'] = $choice->id;
$eventdata['context'] = $context;
$eventdata['courseid'] = $course->id;
$event = \mod_choice\event\course_module_viewed::create($eventdata);
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->trigger();
/// Check to see if groups are being used in this choice

View File

@ -260,6 +260,8 @@
'objectid' => $data->id
);
$event = \mod_data\event\course_module_viewed::create($params);
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('data', $data);
$event->trigger();

View File

@ -92,9 +92,6 @@ class course_module_viewed extends \core\event\course_module_viewed {
if (!isset($this->other['anonymous'])) {
throw new \coding_exception("Field other['anonymous'] cannot be empty");
}
if (!isset($this->other['cmid'])) {
throw new \coding_exception("Field other['cmid'] cannot be empty");
}
// Call parent validations.
parent::validate_data();

View File

@ -176,39 +176,11 @@ class mod_feedback_events_testcase extends advanced_testcase {
$context = context_module::instance($this->eventcm->id);
// Test not setting instanceid.
try {
\mod_feedback\event\response_deleted::create(array(
'context' => $context,
'objectid' => $this->eventfeedbackcompleted->id,
'other' => array('cmid' => $this->eventcm->id, 'anonymous' => 2)
));
$this->assertEventContextNotUsed($event);
$this->fail("Event validation should not allow \\mod_feedback\\event\\response_deleted to be triggered without
other['instanceid']");
} catch (coding_exception $e) {
$this->assertContains("Field other['instanceid'] cannot be empty", $e->getMessage());
}
// Test not setting cmid.
try {
\mod_feedback\event\response_deleted::create(array(
'context' => $context,
'objectid' => $this->eventfeedbackcompleted->id,
'other' => array('instanceid' => $this->eventfeedback->id, 'anonymous' => 2)
));
$this->fail("Event validation should not allow \\mod_feedback\\event\\response_deleted to be triggered without
other['cmid']");
} catch (coding_exception $e) {
$this->assertContains("Field other['cmid'] cannot be empty", $e->getMessage());
}
// Test not setting anonymous.
// Test not setting other['anonymous'].
try {
\mod_feedback\event\response_submitted::create(array(
'context' => $context,
'objectid' => $this->eventfeedbackcompleted->id,
'other' => array('cmid' => $this->eventcm->id, 'instanceid' => $this->eventfeedback->id)
'objectid' => $this->eventfeedbackcompleted->id
));
$this->fail("Event validation should not allow \\mod_feedback\\event\\response_deleted to be triggered without
other['anonymous']");
@ -252,8 +224,6 @@ class mod_feedback_events_testcase extends advanced_testcase {
$this->assertEquals($USER->id, $event->userid);
$this->assertEquals($USER->id, $event->relateduserid);
$this->assertEquals('feedback_completed', $event->objecttable);
$this->assertEquals($this->eventcm->id, $event->other['cmid']);
$this->assertEquals($this->eventcm->instance, $event->other['instanceid']);
$this->assertEquals(FEEDBACK_ANONYMOUS_YES, $event->other['anonymous']);
$this->setUser($this->eventuser);
$this->assertFalse($event->can_view());

View File

@ -101,11 +101,9 @@ $event = \mod_feedback\event\course_module_viewed::create(array(
'objectid' => $feedback->id,
'context' => $context,
'other' => array(
'cmid' => $cm->id,
'instanceid' => $feedback->id,
'anonymous' => $feedback->anonymous
)
));
)
));
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('feedback', $feedback);

View File

@ -54,6 +54,8 @@ $params = array(
'objectid' => $folder->id
);
$event = \mod_folder\event\course_module_viewed::create($params);
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('folder', $folder);
$event->trigger();

View File

@ -33,7 +33,7 @@ defined('MOODLE_INTERNAL') || die();
* @copyright 2014 Dan Poltawski <dan@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class forum_viewed extends \core\event\base {
class course_module_viewed extends \core\event\course_module_viewed {
/**
* Init method.
@ -46,31 +46,13 @@ class forum_viewed extends \core\event\base {
$this->data['objecttable'] = 'forum';
}
/**
* Returns description of what happened.
*
* @return string
*/
public function get_description() {
return "The user {$this->userid} has viewed the forum {$this->objectid}";
}
/**
* Return localised event name.
*
* @return string
*/
public static function get_name() {
return get_string('eventforumviewed', 'mod_forum');
}
/**
* Get URL related to the action
*
* @return \moodle_url
*/
public function get_url() {
return new \moodle_url('/mod/forum/view.php', array('d' => $this->objectid));
return new \moodle_url('/mod/forum/view.php', array('f' => $this->objectid));
}
/**
@ -83,24 +65,5 @@ class forum_viewed extends \core\event\base {
$this->objectid, $this->contextinstanceid);
}
/**
* Custom validation.
*
* @throws \coding_exception
* @return void
*/
protected function validate_data() {
parent::validate_data();
if ($this->contextlevel != CONTEXT_MODULE) {
throw new \coding_exception('Context passed must be module context.');
}
if (!isset($this->objectid)) {
throw new \coding_exception('objectid must be set to the forumid.');
}
}
}

View File

@ -150,7 +150,6 @@ $string['eventdiscussionupdated'] = 'Discussion updated';
$string['eventdiscussiondeleted'] = 'Discussion deleted';
$string['eventdiscussionmoved'] = 'Discussion moved';
$string['eventdiscussionviewed'] = 'Discussion viewed';
$string['eventforumviewed'] = 'Forum viewed';
$string['eventuserreportviewed'] = 'User report viewed';
$string['eventpostcreated'] = 'Post created';
$string['eventpostdeleted'] = 'Post deleted';

View File

@ -595,9 +595,9 @@ class mod_forum_events_testcase extends advanced_testcase {
}
/**
* Ensure forum_viewed event validates that the forumid is set.
* Ensure course_module_viewed event validates that the forumid is set.
*/
public function test_forum_viewed_objectid_validation() {
public function test_course_module_viewed_objectid_validation() {
$course = $this->getDataGenerator()->create_course();
$forum = $this->getDataGenerator()->create_module('forum', array('course' => $course->id));
$context = context_module::instance($forum->cmid);
@ -606,14 +606,14 @@ class mod_forum_events_testcase extends advanced_testcase {
'context' => $context,
);
$this->setExpectedException('coding_exception', 'objectid must be set to the forumid.');
\mod_forum\event\forum_viewed::create($params);
$this->setExpectedException('coding_exception', 'must define objectid');
\mod_forum\event\course_module_viewed::create($params);
}
/**
* Ensure forum_viewed event validates that the contextlevel is correct.
* Ensure course_module_viewed event validates that the contextlevel is correct.
*/
public function test_forum_viewed_context_validation() {
public function test_course_module_viewed_context_validation() {
$course = $this->getDataGenerator()->create_course();
$forum = $this->getDataGenerator()->create_module('forum', array('course' => $course->id));
@ -623,13 +623,13 @@ class mod_forum_events_testcase extends advanced_testcase {
);
$this->setExpectedException('coding_exception', 'Context passed must be module context.');
\mod_forum\event\forum_viewed::create($params);
\mod_forum\event\course_module_viewed::create($params);
}
/**
* Test the forum_viewed event.
* Test the course_module_viewed event.
*/
public function test_forum_viewed() {
public function test_course_module_viewed() {
// Setup test data.
$course = $this->getDataGenerator()->create_course();
$forum = $this->getDataGenerator()->create_module('forum', array('course' => $course->id));
@ -641,7 +641,7 @@ class mod_forum_events_testcase extends advanced_testcase {
'objectid' => $forum->id,
);
$event = \mod_forum\event\forum_viewed::create($params);
$event = \mod_forum\event\course_module_viewed::create($params);
// Trigger and capture the event.
$sink = $this->redirectEvents();
@ -651,7 +651,7 @@ class mod_forum_events_testcase extends advanced_testcase {
$event = reset($events);
// Checking that the event contains the expected values.
$this->assertInstanceOf('\mod_forum\event\forum_viewed', $event);
$this->assertInstanceOf('\mod_forum\event\course_module_viewed', $event);
$this->assertEquals($context, $event->get_context());
$expected = array($course->id, 'forum', 'view forum', "view.php?f={$forum->id}", $forum->id, $forum->cmid);
$this->assertEventLegacyLogData($expected, $event);

View File

@ -133,7 +133,9 @@
'context' => $context,
'objectid' => $forum->id
);
$event = \mod_forum\event\forum_viewed::create($params);
$event = \mod_forum\event\course_module_viewed::create($params);
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('forum', $forum);
$event->trigger();

View File

@ -287,9 +287,10 @@ if ($pageid != LESSON_EOL) {
// Trigger module viewed event.
$event = \mod_lesson\event\course_module_viewed::create(array(
'objectid' => $lesson->id,
'context' => $context,
'courseid' => $course->id
'context' => $context
));
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->trigger();
// This is where several messages (usually warnings) are displayed

View File

@ -100,6 +100,8 @@ $params = array(
'objectid' => $lti->id
);
$event = \mod_lti\event\course_module_viewed::create($params);
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('lti', $lti);
$event->trigger();

View File

@ -57,6 +57,8 @@ $params = array(
'objectid' => $resource->id
);
$event = \mod_resource\event\course_module_viewed::create($params);
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('resource', $resource);
$event->trigger();

View File

@ -118,6 +118,7 @@ $event = \mod_scorm\event\course_module_viewed::create(array(
'objectid' => $scorm->id,
'context' => $contextmodule,
));
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('scorm', $scorm);
$event->add_record_snapshot('course_modules', $cm);
$event->trigger();

View File

@ -48,10 +48,11 @@ require_capability('mod/url:view', $context);
$params = array(
'context' => $context,
'objectid' => $url->id,
'courseid' => $course->id
'objectid' => $url->id
);
$event = \mod_url\event\course_module_viewed::create($params);
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('url', $url);
$event->trigger();

View File

@ -296,7 +296,6 @@ if($pageid) {
)
);
$event->add_record_snapshot('wiki_pages', $page);
$event->trigger();
} else if($id) {
$event = \mod_wiki\event\course_module_viewed::create(
array(
@ -304,8 +303,6 @@ if($pageid) {
'objectid' => $wiki->id
)
);
$event->add_record_snapshot('wiki', $wiki);
$event->trigger();
} else if($wid && $title) {
$event = \mod_wiki\event\page_viewed::create(
array(
@ -320,9 +317,11 @@ if($pageid) {
)
);
$event->add_record_snapshot('wiki_pages', $page);
$event->add_record_snapshot('wiki', $wiki);
$event->trigger();
}
$event->add_record_snapshot('course_modules', $cm);
$event->add_record_snapshot('course', $course);
$event->add_record_snapshot('wiki', $wiki);
$event->trigger();
$wikipage->print_header();
$wikipage->print_content();

View File

@ -61,7 +61,6 @@ $completion->set_module_viewed($cm);
$eventdata = array();
$eventdata['objectid'] = $workshop->id;
$eventdata['context'] = $workshop->context;
$eventdata['courseid'] = $course->id;
$PAGE->set_url($workshop->view_url());
$event = \mod_workshop\event\course_module_viewed::create($eventdata);