Example #1
0
 /**
  * Tests the filter_users (bulk checking) function. Also tests the SQL
  * variant get_user_list_sql.
  */
 public function test_filter_users()
 {
     global $DB;
     $this->resetAfterTest();
     // Erase static cache before test.
     condition::wipe_static_cache();
     // Make a test course and some users.
     $generator = $this->getDataGenerator();
     $course = $generator->create_course();
     $roleids = $DB->get_records_menu('role', null, '', 'shortname, id');
     $teacher = $generator->create_user();
     $generator->enrol_user($teacher->id, $course->id, $roleids['editingteacher']);
     $allusers = array($teacher->id => $teacher);
     $students = array();
     for ($i = 0; $i < 3; $i++) {
         $student = $generator->create_user();
         $students[$i] = $student;
         $generator->enrol_user($student->id, $course->id, $roleids['student']);
         $allusers[$student->id] = $student;
     }
     $info = new \core_availability\mock_info($course);
     // Make test groups.
     $group1 = $generator->create_group(array('courseid' => $course->id));
     $group2 = $generator->create_group(array('courseid' => $course->id));
     // Assign students to groups as follows (teacher is not in a group):
     // 0: no groups.
     // 1: in group 1.
     // 2: in group 2.
     groups_add_member($group1, $students[1]);
     groups_add_member($group2, $students[2]);
     // Test 'any group' condition.
     $checker = new \core_availability\capability_checker($info->get_context());
     $cond = new condition((object) array());
     $result = array_keys($cond->filter_user_list($allusers, false, $info, $checker));
     ksort($result);
     $expected = array($teacher->id, $students[1]->id, $students[2]->id);
     $this->assertEquals($expected, $result);
     // Test it with get_user_list_sql.
     list($sql, $params) = $cond->get_user_list_sql(false, $info, true);
     $result = $DB->get_fieldset_sql($sql, $params);
     sort($result);
     $this->assertEquals($expected, $result);
     // Test NOT version (note that teacher can still access because AAG works
     // both ways).
     $result = array_keys($cond->filter_user_list($allusers, true, $info, $checker));
     ksort($result);
     $expected = array($teacher->id, $students[0]->id);
     $this->assertEquals($expected, $result);
     // Test with get_user_list_sql.
     list($sql, $params) = $cond->get_user_list_sql(true, $info, true);
     $result = $DB->get_fieldset_sql($sql, $params);
     sort($result);
     $this->assertEquals($expected, $result);
     // Test specific group.
     $cond = new condition((object) array('id' => (int) $group1->id));
     $result = array_keys($cond->filter_user_list($allusers, false, $info, $checker));
     ksort($result);
     $expected = array($teacher->id, $students[1]->id);
     $this->assertEquals($expected, $result);
     list($sql, $params) = $cond->get_user_list_sql(false, $info, true);
     $result = $DB->get_fieldset_sql($sql, $params);
     sort($result);
     $this->assertEquals($expected, $result);
     $result = array_keys($cond->filter_user_list($allusers, true, $info, $checker));
     ksort($result);
     $expected = array($teacher->id, $students[0]->id, $students[2]->id);
     $this->assertEquals($expected, $result);
     list($sql, $params) = $cond->get_user_list_sql(true, $info, true);
     $result = $DB->get_fieldset_sql($sql, $params);
     sort($result);
     $this->assertEquals($expected, $result);
 }