You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
404 lines
16 KiB
404 lines
16 KiB
2 years ago
|
<?php
|
||
|
// This file is part of Moodle - http://moodle.org/
|
||
|
//
|
||
|
// Moodle is free software: you can redistribute it and/or modify
|
||
|
// it under the terms of the GNU General Public License as published by
|
||
|
// the Free Software Foundation, either version 3 of the License, or
|
||
|
// (at your option) any later version.
|
||
|
//
|
||
|
// Moodle is distributed in the hope that it will be useful,
|
||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
// GNU General Public License for more details.
|
||
|
//
|
||
|
// You should have received a copy of the GNU General Public License
|
||
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
||
|
|
||
|
/**
|
||
|
* Events tests.
|
||
|
*
|
||
|
* @package mod_choice
|
||
|
* @copyright 2013 Adrian Greeve <adrian@moodle.com>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
|
||
|
defined('MOODLE_INTERNAL') || die();
|
||
|
|
||
|
global $CFG;
|
||
|
require_once($CFG->dirroot . '/mod/choice/lib.php');
|
||
|
|
||
|
/**
|
||
|
* Events tests class.
|
||
|
*
|
||
|
* @package mod_choice
|
||
|
* @copyright 2013 Adrian Greeve <adrian@moodle.com>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
class mod_choice_events_testcase extends advanced_testcase {
|
||
|
/** @var choice_object */
|
||
|
protected $choice;
|
||
|
|
||
|
/** @var course_object */
|
||
|
protected $course;
|
||
|
|
||
|
/** @var cm_object Course module object. */
|
||
|
protected $cm;
|
||
|
|
||
|
/** @var context_object */
|
||
|
protected $context;
|
||
|
|
||
|
/**
|
||
|
* Setup often used objects for the following tests.
|
||
|
*/
|
||
|
protected function setup() {
|
||
|
global $DB;
|
||
|
|
||
|
$this->resetAfterTest();
|
||
|
|
||
|
$this->course = $this->getDataGenerator()->create_course();
|
||
|
$this->choice = $this->getDataGenerator()->create_module('choice', array('course' => $this->course->id));
|
||
|
$this->cm = $DB->get_record('course_modules', array('id' => $this->choice->cmid));
|
||
|
$this->context = context_module::instance($this->choice->cmid);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test to ensure that event data is being stored correctly.
|
||
|
*/
|
||
|
public function test_answer_created() {
|
||
|
global $DB;
|
||
|
// Generate user data.
|
||
|
$user = $this->getDataGenerator()->create_user();
|
||
|
$this->setUser($user);
|
||
|
|
||
|
$optionids = array_keys($DB->get_records('choice_options', array('choiceid' => $this->choice->id)));
|
||
|
// Redirect event.
|
||
|
$sink = $this->redirectEvents();
|
||
|
choice_user_submit_response($optionids[3], $this->choice, $user->id, $this->course, $this->cm);
|
||
|
$events = $sink->get_events();
|
||
|
$answer = $DB->get_record('choice_answers', ['userid' => $user->id, 'choiceid' => $this->choice->id]);
|
||
|
|
||
|
// Data checking.
|
||
|
$this->assertCount(1, $events);
|
||
|
$this->assertInstanceOf('\mod_choice\event\answer_created', $events[0]);
|
||
|
$this->assertEquals($user->id, $events[0]->userid);
|
||
|
$this->assertEquals($user->id, $events[0]->relateduserid);
|
||
|
$this->assertEquals(context_module::instance($this->choice->cmid), $events[0]->get_context());
|
||
|
$this->assertEquals($answer->id, $events[0]->objectid);
|
||
|
$this->assertEquals($this->choice->id, $events[0]->other['choiceid']);
|
||
|
$this->assertEquals($optionids[3], $events[0]->other['optionid']);
|
||
|
$this->assertEventContextNotUsed($events[0]);
|
||
|
$sink->close();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test to ensure that event data is being stored correctly.
|
||
|
*/
|
||
|
public function test_answer_submitted_by_another_user() {
|
||
|
global $DB, $USER;
|
||
|
// Generate user data.
|
||
|
$user = $this->getDataGenerator()->create_user();
|
||
|
|
||
|
$optionids = array_keys($DB->get_records('choice_options', array('choiceid' => $this->choice->id)));
|
||
|
// Redirect event.
|
||
|
$sink = $this->redirectEvents();
|
||
|
choice_user_submit_response($optionids[3], $this->choice, $user->id, $this->course, $this->cm);
|
||
|
$events = $sink->get_events();
|
||
|
$answer = $DB->get_record('choice_answers', ['userid' => $user->id, 'choiceid' => $this->choice->id]);
|
||
|
|
||
|
// Data checking.
|
||
|
$this->assertCount(1, $events);
|
||
|
$this->assertInstanceOf('\mod_choice\event\answer_created', $events[0]);
|
||
|
$this->assertEquals($USER->id, $events[0]->userid);
|
||
|
$this->assertEquals($user->id, $events[0]->relateduserid);
|
||
|
$this->assertEquals(context_module::instance($this->choice->cmid), $events[0]->get_context());
|
||
|
$this->assertEquals($answer->id, $events[0]->objectid);
|
||
|
$this->assertEquals($this->choice->id, $events[0]->other['choiceid']);
|
||
|
$this->assertEquals($optionids[3], $events[0]->other['optionid']);
|
||
|
$this->assertEventContextNotUsed($events[0]);
|
||
|
$sink->close();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test to ensure that multiple choice data is being stored correctly.
|
||
|
*/
|
||
|
public function test_answer_created_multiple() {
|
||
|
global $DB;
|
||
|
|
||
|
// Generate user data.
|
||
|
$user = $this->getDataGenerator()->create_user();
|
||
|
$this->setUser($user);
|
||
|
|
||
|
// Create multiple choice.
|
||
|
$choice = $this->getDataGenerator()->create_module('choice', array('course' => $this->course->id,
|
||
|
'allowmultiple' => 1));
|
||
|
$cm = $DB->get_record('course_modules', array('id' => $choice->cmid));
|
||
|
$context = context_module::instance($choice->cmid);
|
||
|
|
||
|
$optionids = array_keys($DB->get_records('choice_options', array('choiceid' => $choice->id)));
|
||
|
$submittedoptionids = array($optionids[1], $optionids[3]);
|
||
|
|
||
|
// Redirect event.
|
||
|
$sink = $this->redirectEvents();
|
||
|
choice_user_submit_response($submittedoptionids, $choice, $user->id, $this->course, $cm);
|
||
|
$events = $sink->get_events();
|
||
|
$answers = $DB->get_records('choice_answers', ['userid' => $user->id, 'choiceid' => $choice->id], 'id');
|
||
|
$answers = array_values($answers);
|
||
|
|
||
|
// Data checking.
|
||
|
$this->assertCount(2, $events);
|
||
|
$this->assertInstanceOf('\mod_choice\event\answer_created', $events[0]);
|
||
|
$this->assertEquals($user->id, $events[0]->userid);
|
||
|
$this->assertEquals($user->id, $events[0]->relateduserid);
|
||
|
$this->assertEquals(context_module::instance($choice->cmid), $events[0]->get_context());
|
||
|
$this->assertEquals($answers[0]->id, $events[0]->objectid);
|
||
|
$this->assertEquals($choice->id, $events[0]->other['choiceid']);
|
||
|
$this->assertEquals($optionids[1], $events[0]->other['optionid']);
|
||
|
$this->assertEventContextNotUsed($events[0]);
|
||
|
|
||
|
$this->assertInstanceOf('\mod_choice\event\answer_created', $events[1]);
|
||
|
$this->assertEquals($user->id, $events[1]->userid);
|
||
|
$this->assertEquals($user->id, $events[1]->relateduserid);
|
||
|
$this->assertEquals(context_module::instance($choice->cmid), $events[1]->get_context());
|
||
|
$this->assertEquals($answers[1]->id, $events[1]->objectid);
|
||
|
$this->assertEquals($choice->id, $events[1]->other['choiceid']);
|
||
|
$this->assertEquals($optionids[3], $events[1]->other['optionid']);
|
||
|
$this->assertEventContextNotUsed($events[1]);
|
||
|
$sink->close();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test custom validations.
|
||
|
*
|
||
|
* @expectedException coding_exception
|
||
|
*/
|
||
|
public function test_answer_created_other_exception() {
|
||
|
// Generate user data.
|
||
|
$user = $this->getDataGenerator()->create_user();
|
||
|
|
||
|
$eventdata = array();
|
||
|
$eventdata['context'] = $this->context;
|
||
|
$eventdata['objectid'] = 2;
|
||
|
$eventdata['userid'] = $user->id;
|
||
|
$eventdata['courseid'] = $this->course->id;
|
||
|
$eventdata['other'] = array();
|
||
|
|
||
|
// Make sure content identifier is always set.
|
||
|
$event = \mod_choice\event\answer_created::create($eventdata);
|
||
|
$event->trigger();
|
||
|
$this->assertEventContextNotUsed($event);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test to ensure that event data is being stored correctly.
|
||
|
*/
|
||
|
public function test_answer_updated() {
|
||
|
global $DB;
|
||
|
// Generate user data.
|
||
|
$user = $this->getDataGenerator()->create_user();
|
||
|
$this->setUser($user);
|
||
|
|
||
|
$optionids = array_keys($DB->get_records('choice_options', array('choiceid' => $this->choice->id)));
|
||
|
|
||
|
// Create the first answer.
|
||
|
choice_user_submit_response($optionids[2], $this->choice, $user->id, $this->course, $this->cm);
|
||
|
$oldanswer = $DB->get_record('choice_answers', ['userid' => $user->id, 'choiceid' => $this->choice->id]);
|
||
|
|
||
|
// Redirect event.
|
||
|
$sink = $this->redirectEvents();
|
||
|
// Now choose a different answer.
|
||
|
choice_user_submit_response($optionids[3], $this->choice, $user->id, $this->course, $this->cm);
|
||
|
$newanswer = $DB->get_record('choice_answers', ['userid' => $user->id, 'choiceid' => $this->choice->id]);
|
||
|
|
||
|
$events = $sink->get_events();
|
||
|
|
||
|
// Data checking.
|
||
|
$this->assertCount(2, $events);
|
||
|
$this->assertInstanceOf('\mod_choice\event\answer_deleted', $events[0]);
|
||
|
$this->assertEquals($user->id, $events[0]->userid);
|
||
|
$this->assertEquals(context_module::instance($this->choice->cmid), $events[0]->get_context());
|
||
|
$this->assertEquals($oldanswer->id, $events[0]->objectid);
|
||
|
$this->assertEquals($this->choice->id, $events[0]->other['choiceid']);
|
||
|
$this->assertEquals($optionids[2], $events[0]->other['optionid']);
|
||
|
$this->assertEventContextNotUsed($events[0]);
|
||
|
|
||
|
$this->assertInstanceOf('\mod_choice\event\answer_created', $events[1]);
|
||
|
$this->assertEquals($user->id, $events[1]->userid);
|
||
|
$this->assertEquals(context_module::instance($this->choice->cmid), $events[1]->get_context());
|
||
|
$this->assertEquals($newanswer->id, $events[1]->objectid);
|
||
|
$this->assertEquals($this->choice->id, $events[1]->other['choiceid']);
|
||
|
$this->assertEquals($optionids[3], $events[1]->other['optionid']);
|
||
|
$this->assertEventContextNotUsed($events[1]);
|
||
|
|
||
|
$sink->close();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test to ensure that event data is being stored correctly.
|
||
|
*/
|
||
|
public function test_answer_deleted() {
|
||
|
global $DB, $USER;
|
||
|
// Generate user data.
|
||
|
$user = $this->getDataGenerator()->create_user();
|
||
|
|
||
|
$optionids = array_keys($DB->get_records('choice_options', array('choiceid' => $this->choice->id)));
|
||
|
|
||
|
// Create the first answer.
|
||
|
choice_user_submit_response($optionids[2], $this->choice, $user->id, $this->course, $this->cm);
|
||
|
// Get the users response.
|
||
|
$answer = $DB->get_record('choice_answers', array('userid' => $user->id, 'choiceid' => $this->choice->id),
|
||
|
'*', $strictness = IGNORE_MULTIPLE);
|
||
|
|
||
|
// Redirect event.
|
||
|
$sink = $this->redirectEvents();
|
||
|
// Now delete the answer.
|
||
|
choice_delete_responses(array($answer->id), $this->choice, $this->cm, $this->course);
|
||
|
|
||
|
// Get our event event.
|
||
|
$events = $sink->get_events();
|
||
|
$event = reset($events);
|
||
|
|
||
|
// Data checking.
|
||
|
$this->assertInstanceOf('\mod_choice\event\answer_deleted', $event);
|
||
|
$this->assertEquals($USER->id, $event->userid);
|
||
|
$this->assertEquals($user->id, $event->relateduserid);
|
||
|
$this->assertEquals(context_module::instance($this->choice->cmid), $event->get_context());
|
||
|
$this->assertEquals($this->choice->id, $event->other['choiceid']);
|
||
|
$this->assertEquals($answer->optionid, $event->other['optionid']);
|
||
|
$this->assertEventContextNotUsed($event);
|
||
|
$sink->close();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test to ensure that event data is being stored correctly.
|
||
|
*/
|
||
|
public function test_report_viewed() {
|
||
|
global $USER;
|
||
|
|
||
|
$this->resetAfterTest();
|
||
|
|
||
|
// Generate user data.
|
||
|
$this->setAdminUser();
|
||
|
|
||
|
$eventdata = array();
|
||
|
$eventdata['objectid'] = $this->choice->id;
|
||
|
$eventdata['context'] = $this->context;
|
||
|
$eventdata['courseid'] = $this->course->id;
|
||
|
$eventdata['other']['content'] = 'choicereportcontentviewed';
|
||
|
|
||
|
// This is fired in a page view so we can't run this through a function.
|
||
|
$event = \mod_choice\event\report_viewed::create($eventdata);
|
||
|
|
||
|
// Redirect event.
|
||
|
$sink = $this->redirectEvents();
|
||
|
$event->trigger();
|
||
|
$event = $sink->get_events();
|
||
|
|
||
|
// Data checking.
|
||
|
$this->assertCount(1, $event);
|
||
|
$this->assertInstanceOf('\mod_choice\event\report_viewed', $event[0]);
|
||
|
$this->assertEquals($USER->id, $event[0]->userid);
|
||
|
$this->assertEquals(context_module::instance($this->choice->cmid), $event[0]->get_context());
|
||
|
$expected = array($this->course->id, "choice", "report", 'report.php?id=' . $this->context->instanceid,
|
||
|
$this->choice->id, $this->context->instanceid);
|
||
|
$this->assertEventLegacyLogData($expected, $event[0]);
|
||
|
$this->assertEventContextNotUsed($event[0]);
|
||
|
$sink->close();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test to ensure that event data is being stored correctly.
|
||
|
*/
|
||
|
public function test_report_downloaded() {
|
||
|
global $USER;
|
||
|
|
||
|
$this->resetAfterTest();
|
||
|
|
||
|
// Generate user data.
|
||
|
$this->setAdminUser();
|
||
|
|
||
|
$eventdata = array();
|
||
|
$eventdata['context'] = $this->context;
|
||
|
$eventdata['courseid'] = $this->course->id;
|
||
|
$eventdata['other']['content'] = 'choicereportcontentviewed';
|
||
|
$eventdata['other']['format'] = 'csv';
|
||
|
$eventdata['other']['choiceid'] = $this->choice->id;
|
||
|
|
||
|
// This is fired in a page view so we can't run this through a function.
|
||
|
$event = \mod_choice\event\report_downloaded::create($eventdata);
|
||
|
|
||
|
// Redirect event.
|
||
|
$sink = $this->redirectEvents();
|
||
|
$event->trigger();
|
||
|
$event = $sink->get_events();
|
||
|
|
||
|
// Data checking.
|
||
|
$this->assertCount(1, $event);
|
||
|
$this->assertInstanceOf('\mod_choice\event\report_downloaded', $event[0]);
|
||
|
$this->assertEquals($USER->id, $event[0]->userid);
|
||
|
$this->assertEquals(context_module::instance($this->choice->cmid), $event[0]->get_context());
|
||
|
$this->assertEquals('csv', $event[0]->other['format']);
|
||
|
$this->assertEquals($this->choice->id, $event[0]->other['choiceid']);
|
||
|
$this->assertEventContextNotUsed($event[0]);
|
||
|
$sink->close();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test to ensure that event data is being stored correctly.
|
||
|
*/
|
||
|
public function test_course_module_viewed() {
|
||
|
global $USER;
|
||
|
|
||
|
// Generate user data.
|
||
|
$this->setAdminUser();
|
||
|
|
||
|
$eventdata = array();
|
||
|
$eventdata['objectid'] = $this->choice->id;
|
||
|
$eventdata['context'] = $this->context;
|
||
|
$eventdata['courseid'] = $this->course->id;
|
||
|
$eventdata['other']['content'] = 'pageresourceview';
|
||
|
|
||
|
// This is fired in a page view so we can't run this through a function.
|
||
|
$event = \mod_choice\event\course_module_viewed::create($eventdata);
|
||
|
|
||
|
// Redirect event.
|
||
|
$sink = $this->redirectEvents();
|
||
|
$event->trigger();
|
||
|
$event = $sink->get_events();
|
||
|
|
||
|
// Data checking.
|
||
|
$this->assertCount(1, $event);
|
||
|
$this->assertInstanceOf('\mod_choice\event\course_module_viewed', $event[0]);
|
||
|
$this->assertEquals($USER->id, $event[0]->userid);
|
||
|
$this->assertEquals(context_module::instance($this->choice->cmid), $event[0]->get_context());
|
||
|
$expected = array($this->course->id, "choice", "view", 'view.php?id=' . $this->context->instanceid,
|
||
|
$this->choice->id, $this->context->instanceid);
|
||
|
$this->assertEventLegacyLogData($expected, $event[0]);
|
||
|
$this->assertEventContextNotUsed($event[0]);
|
||
|
$sink->close();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test to ensure that event data is being stored correctly.
|
||
|
*/
|
||
|
public function test_course_module_instance_list_viewed_viewed() {
|
||
|
global $USER;
|
||
|
|
||
|
// Not much can be tested here as the event is only triggered on a page load,
|
||
|
// let's just check that the event contains the expected basic information.
|
||
|
$this->setAdminUser();
|
||
|
|
||
|
$params = array('context' => context_course::instance($this->course->id));
|
||
|
$event = \mod_choice\event\course_module_instance_list_viewed::create($params);
|
||
|
$sink = $this->redirectEvents();
|
||
|
$event->trigger();
|
||
|
$events = $sink->get_events();
|
||
|
$event = reset($events);
|
||
|
$this->assertInstanceOf('\mod_choice\event\course_module_instance_list_viewed', $event);
|
||
|
$this->assertEquals($USER->id, $event->userid);
|
||
|
$this->assertEquals(context_course::instance($this->course->id), $event->get_context());
|
||
|
$expected = array($this->course->id, 'choice', 'view all', 'index.php?id=' . $this->course->id, '');
|
||
|
$this->assertEventLegacyLogData($expected, $event);
|
||
|
$this->assertEventContextNotUsed($event);
|
||
|
}
|
||
|
}
|