2 // This file is part of Moodle - http://moodle.org/
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
18 * Course global search unit tests.
21 * @copyright 2016 Devang Gaur {@link http://www.devanggaur.com}
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
25 defined('MOODLE_INTERNAL') || die();
28 require_once($CFG->dirroot . '/search/tests/fixtures/testable_core_search.php');
31 * Provides the unit tests for course global search.
34 * @copyright 2016 Devang Gaur {@link http://www.davidmonllao.com}
35 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
37 class user_search_testcase extends advanced_testcase {
42 protected $userareaid = null;
44 public function setUp() {
45 $this->resetAfterTest(true);
46 set_config('enableglobalsearch', true);
48 $this->userareaid = \core_search\manager::generate_areaid('core_user', 'user');
50 // Set \core_search::instance to the mock_search_engine as we don't require the search engine to be working to test this.
51 $search = testable_core_search::instance();
55 * Indexing users contents.
59 public function test_users_indexing() {
62 // Returns the instance as long as the area is supported.
63 $searcharea = \core_search\manager::get_search_area($this->userareaid);
64 $this->assertInstanceOf('\core_user\search\user', $searcharea);
66 $user1 = self::getDataGenerator()->create_user();
67 $user2 = self::getDataGenerator()->create_user();
70 // Recordset will produce 4 user records:
71 // Guest User, Admin User and two above generated users.
72 $recordset = $searcharea->get_recordset_by_timestamp(0);
73 $this->assertTrue($recordset->valid());
75 foreach ($recordset as $record) {
76 $this->assertInstanceOf('stdClass', $record);
77 $doc = $searcharea->get_document($record);
78 $this->assertInstanceOf('\core_search\document', $doc);
81 // If there would be an error/failure in the foreach above the recordset would be closed on shutdown.
83 $this->assertEquals(4, $nrecords);
85 // The +2 is to prevent race conditions.
86 $recordset = $searcharea->get_recordset_by_timestamp(time() + 2);
89 $this->assertFalse($recordset->valid());
92 // Context support; first, try an unsupported context type.
93 $coursecontext = context_course::instance($SITE->id);
94 $this->assertNull($searcharea->get_document_recordset(0, $coursecontext));
96 // Try a specific user, will only return 1 record (that user).
97 $rs = $searcharea->get_document_recordset(0, context_user::instance($user1->id));
98 $this->assertEquals(1, iterator_count($rs));
107 public function test_users_document() {
109 // Returns the instance as long as the area is supported.
110 $searcharea = \core_search\manager::get_search_area($this->userareaid);
111 $this->assertInstanceOf('\core_user\search\user', $searcharea);
113 $user = self::getDataGenerator()->create_user();
115 $doc = $searcharea->get_document($user);
116 $this->assertInstanceOf('\core_search\document', $doc);
117 $this->assertEquals($user->id, $doc->get('itemid'));
118 $this->assertEquals($this->userareaid . '-' . $user->id, $doc->get('id'));
119 $this->assertEquals(SITEID, $doc->get('courseid'));
120 $this->assertFalse($doc->is_set('userid'));
121 $this->assertEquals(\core_search\manager::NO_OWNER_ID, $doc->get('owneruserid'));
122 $this->assertEquals(content_to_text(fullname($user), false), $searcharea->get_document_display_title($doc));
123 $this->assertEquals(content_to_text($user->description, $user->descriptionformat), $doc->get('content'));
131 public function test_users_access() {
134 // Returns the instance as long as the area is supported.
135 $searcharea = \core_search\manager::get_search_area($this->userareaid);
137 $user1 = self::getDataGenerator()->create_user();
138 $user2 = self::getDataGenerator()->create_user();
139 $user3 = self::getDataGenerator()->create_user();
140 $user4 = self::getDataGenerator()->create_user();
141 $user5 = self::getDataGenerator()->create_user();
142 $user5->id = 0; // Visitor (not guest).
144 $deleteduser = self::getDataGenerator()->create_user(array('deleted' => 1));
145 $unconfirmeduser = self::getDataGenerator()->create_user(array('confirmed' => 0));
146 $suspendeduser = self::getDataGenerator()->create_user(array('suspended' => 1));
148 $course1 = self::getDataGenerator()->create_course();
149 $course2 = self::getDataGenerator()->create_course();
151 $group1 = $this->getDataGenerator()->create_group(array('courseid' => $course1->id));
152 $group2 = $this->getDataGenerator()->create_group(array('courseid' => $course1->id));
154 $this->getDataGenerator()->enrol_user($user1->id, $course1->id, 'teacher');
155 $this->getDataGenerator()->enrol_user($user2->id, $course1->id, 'student');
156 $this->getDataGenerator()->enrol_user($user2->id, $course2->id, 'student');
157 $this->getDataGenerator()->enrol_user($user3->id, $course2->id, 'student');
158 $this->getDataGenerator()->enrol_user($user4->id, $course2->id, 'student');
159 $this->getDataGenerator()->enrol_user($suspendeduser->id, $course1->id, 'student');
161 $this->getDataGenerator()->create_group_member(array('userid' => $user2->id, 'groupid' => $group1->id));
162 $this->getDataGenerator()->create_group_member(array('userid' => $user3->id, 'groupid' => $group1->id));
163 $this->getDataGenerator()->create_group_member(array('userid' => $user4->id, 'groupid' => $group2->id));
165 $this->setAdminUser();
166 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user1->id));
167 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user2->id));
168 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user3->id));
169 $this->assertEquals(\core_search\manager::ACCESS_DELETED, $searcharea->check_access($deleteduser->id));
170 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($unconfirmeduser->id));
171 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($suspendeduser->id));
172 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access(2));
174 $this->setUser($user1);
175 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user1->id));
176 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user2->id));
177 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($user3->id));
178 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($user4->id));
179 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access(1));// Guest user can't be accessed.
180 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access(2));// Admin user can't be accessed.
181 $this->assertEquals(\core_search\manager::ACCESS_DELETED, $searcharea->check_access(-123));
182 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($unconfirmeduser->id));
183 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($suspendeduser->id));
185 $this->setUser($user2);
186 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user1->id));
187 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user2->id));
188 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user3->id));
189 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user4->id));
191 $this->setUser($user3);
192 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($user1->id));
193 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user2->id));
194 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user3->id));
195 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($suspendeduser->id));
197 $this->setGuestUser();
198 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($user1->id));
199 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($user2->id));
200 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($user3->id));
202 $CFG->forceloginforprofiles = 0;
203 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user1->id));
204 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user2->id));
205 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user3->id));
207 $this->setUser($user5);
208 $CFG->forceloginforprofiles = 1;
209 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($user1->id));
210 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($user2->id));
211 $this->assertEquals(\core_search\manager::ACCESS_DENIED, $searcharea->check_access($user3->id));
213 $CFG->forceloginforprofiles = 0;
214 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user1->id));
215 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user2->id));
216 $this->assertEquals(\core_search\manager::ACCESS_GRANTED, $searcharea->check_access($user3->id));
220 * Test document icon.
222 public function test_get_doc_icon() {
223 $searcharea = \core_search\manager::get_search_area($this->userareaid);
224 $user = self::getDataGenerator()->create_user();
225 $doc = $searcharea->get_document($user);
227 $result = $searcharea->get_doc_icon($doc);
229 $this->assertEquals('i/user', $result->get_name());
230 $this->assertEquals('moodle', $result->get_component());