mirror of
https://github.com/moodle/moodle.git
synced 2025-08-05 00:46:50 +02:00
MDL-60388 analytics: Any write action looking at all contexts below course
This commit is contained in:
parent
9644c0e87a
commit
6e98bca0ba
4 changed files with 159 additions and 1 deletions
|
@ -175,6 +175,61 @@ class core_analytics_indicators_testcase extends advanced_testcase {
|
|||
$this->assertEquals($indicator::get_max_value(), $values[$course1->id][0]);
|
||||
$this->assertEquals($indicator::get_min_value(), $values[$course2->id][0]);
|
||||
|
||||
// Test any write action in the course.
|
||||
$course1 = $this->getDataGenerator()->create_course();
|
||||
$coursecontext1 = \context_course::instance($course1->id);
|
||||
$activity1 = $this->getDataGenerator()->create_module('forum', array('course' => $course1->id));
|
||||
$activity1context = \context_module::instance($activity1->cmid);
|
||||
$course2 = $this->getDataGenerator()->create_course();
|
||||
$coursecontext2 = \context_course::instance($course2->id);
|
||||
$this->getDataGenerator()->enrol_user($user1->id, $course2->id);
|
||||
|
||||
$indicator = new \core\analytics\indicator\any_write_action_in_course();
|
||||
|
||||
$sampleids = array($user1->id => $user1->id, $user2->id => $user2->id);
|
||||
$data = array($user1->id => array(
|
||||
'context' => $coursecontext1,
|
||||
'course' => $course1,
|
||||
'user' => $user1
|
||||
));
|
||||
$data[$user2->id] = $data[$user1->id];
|
||||
$data[$user2->id]['user'] = $user2;
|
||||
$indicator->add_sample_data($data);
|
||||
|
||||
list($values, $unused) = $indicator->calculate($sampleids, 'user');
|
||||
$this->assertEquals($indicator::get_min_value(), $values[$user1->id][0]);
|
||||
$this->assertEquals($indicator::get_min_value(), $values[$user2->id][0]);
|
||||
|
||||
$beforecourseeventcreate = time();
|
||||
sleep(1);
|
||||
|
||||
\logstore_standard\event\unittest_executed::create(
|
||||
array('context' => $activity1context, 'userid' => $user1->id))->trigger();
|
||||
list($values, $unused) = $indicator->calculate($sampleids, 'user');
|
||||
$this->assertEquals($indicator::get_max_value(), $values[$user1->id][0]);
|
||||
$this->assertEquals($indicator::get_min_value(), $values[$user2->id][0]);
|
||||
|
||||
// Now try with course-level samples where user is not available.
|
||||
$sampleids = array($course1->id => $course1->id, $course2->id => $course2->id);
|
||||
$data = array(
|
||||
$course1->id => array(
|
||||
'context' => $coursecontext1,
|
||||
'course' => $course1,
|
||||
),
|
||||
$course2->id => array(
|
||||
'context' => $coursecontext2,
|
||||
'course' => $course2,
|
||||
)
|
||||
);
|
||||
$indicator->clear_sample_data();
|
||||
$indicator->add_sample_data($data);
|
||||
|
||||
// Limited by time to avoid previous logs interfering as other logs
|
||||
// have been generated by the system.
|
||||
list($values, $unused) = $indicator->calculate($sampleids, 'course', $beforecourseeventcreate);
|
||||
$this->assertEquals($indicator::get_max_value(), $values[$course1->id][0]);
|
||||
$this->assertEquals($indicator::get_min_value(), $values[$course2->id][0]);
|
||||
|
||||
// Test read actions.
|
||||
$course = $this->getDataGenerator()->create_course();
|
||||
$coursecontext = \context_course::instance($course->id);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue