manager_test.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. <?php
  2. // This file is part of Moodle - http://moodle.org/
  3. //
  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.
  8. //
  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.
  13. //
  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/>.
  16. /**
  17. * Search manager unit tests.
  18. *
  19. * @package core_search
  20. * @category phpunit
  21. * @copyright 2015 David Monllao {@link http://www.davidmonllao.com}
  22. * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23. */
  24. defined('MOODLE_INTERNAL') || die();
  25. require_once(__DIR__ . '/fixtures/testable_core_search.php');
  26. require_once(__DIR__ . '/fixtures/mock_search_area.php');
  27. /**
  28. * Unit tests for search manager.
  29. *
  30. * @package core_search
  31. * @category phpunit
  32. * @copyright 2015 David Monllao {@link http://www.davidmonllao.com}
  33. * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  34. */
  35. class search_manager_testcase extends advanced_testcase {
  36. protected $forumpostareaid = null;
  37. protected $mycoursesareaid = null;
  38. public function setUp() {
  39. $this->forumpostareaid = \core_search\manager::generate_areaid('mod_forum', 'post');
  40. $this->mycoursesareaid = \core_search\manager::generate_areaid('core_course', 'mycourse');
  41. }
  42. public function test_search_enabled() {
  43. $this->resetAfterTest();
  44. // Disabled by default.
  45. $this->assertFalse(\core_search\manager::is_global_search_enabled());
  46. set_config('enableglobalsearch', true);
  47. $this->assertTrue(\core_search\manager::is_global_search_enabled());
  48. set_config('enableglobalsearch', false);
  49. $this->assertFalse(\core_search\manager::is_global_search_enabled());
  50. }
  51. public function test_search_areas() {
  52. global $CFG;
  53. $this->resetAfterTest();
  54. set_config('enableglobalsearch', true);
  55. $fakeareaid = \core_search\manager::generate_areaid('mod_unexisting', 'chihuaquita');
  56. $searcharea = \core_search\manager::get_search_area($this->forumpostareaid);
  57. $this->assertInstanceOf('\core_search\base', $searcharea);
  58. $this->assertFalse(\core_search\manager::get_search_area($fakeareaid));
  59. $this->assertArrayHasKey($this->forumpostareaid, \core_search\manager::get_search_areas_list());
  60. $this->assertArrayNotHasKey($fakeareaid, \core_search\manager::get_search_areas_list());
  61. // Enabled by default once global search is enabled.
  62. $this->assertArrayHasKey($this->forumpostareaid, \core_search\manager::get_search_areas_list(true));
  63. list($componentname, $varname) = $searcharea->get_config_var_name();
  64. set_config($varname . '_enabled', 0, $componentname);
  65. \core_search\manager::clear_static();
  66. $this->assertArrayNotHasKey('mod_forum', \core_search\manager::get_search_areas_list(true));
  67. set_config($varname . '_enabled', 1, $componentname);
  68. // Although the result is wrong, we want to check that \core_search\manager::get_search_areas_list returns cached results.
  69. $this->assertArrayNotHasKey($this->forumpostareaid, \core_search\manager::get_search_areas_list(true));
  70. // Now we check the real result.
  71. \core_search\manager::clear_static();
  72. $this->assertArrayHasKey($this->forumpostareaid, \core_search\manager::get_search_areas_list(true));
  73. }
  74. public function test_search_config() {
  75. $this->resetAfterTest();
  76. $search = testable_core_search::instance();
  77. // We should test both plugin types and core subsystems. No core subsystems available yet.
  78. $searcharea = $search->get_search_area($this->forumpostareaid);
  79. list($componentname, $varname) = $searcharea->get_config_var_name();
  80. // Just with a couple of vars should be enough.
  81. $start = time() - 100;
  82. $end = time();
  83. set_config($varname . '_indexingstart', $start, $componentname);
  84. set_config($varname . '_indexingend', $end, $componentname);
  85. $configs = $search->get_areas_config(array($this->forumpostareaid => $searcharea));
  86. $this->assertEquals($start, $configs[$this->forumpostareaid]->indexingstart);
  87. $this->assertEquals($end, $configs[$this->forumpostareaid]->indexingend);
  88. try {
  89. $fakeareaid = \core_search\manager::generate_areaid('mod_unexisting', 'chihuaquita');
  90. $search->reset_config($fakeareaid);
  91. $this->fail('An exception should be triggered if the provided search area does not exist.');
  92. } catch (moodle_exception $ex) {
  93. $this->assertContains($fakeareaid . ' search area is not available.', $ex->getMessage());
  94. }
  95. // We clean it all but enabled components.
  96. $search->reset_config($this->forumpostareaid);
  97. $config = $searcharea->get_config();
  98. $this->assertEquals(1, $config[$varname . '_enabled']);
  99. $this->assertEquals(0, $config[$varname . '_indexingstart']);
  100. $this->assertEquals(0, $config[$varname . '_indexingend']);
  101. $this->assertEquals(0, $config[$varname . '_lastindexrun']);
  102. // No caching.
  103. $configs = $search->get_areas_config(array($this->forumpostareaid => $searcharea));
  104. $this->assertEquals(0, $configs[$this->forumpostareaid]->indexingstart);
  105. $this->assertEquals(0, $configs[$this->forumpostareaid]->indexingend);
  106. set_config($varname . '_indexingstart', $start, $componentname);
  107. set_config($varname . '_indexingend', $end, $componentname);
  108. // All components config should be reset.
  109. $search->reset_config();
  110. $this->assertEquals(0, get_config($componentname, $varname . '_indexingstart'));
  111. $this->assertEquals(0, get_config($componentname, $varname . '_indexingend'));
  112. $this->assertEquals(0, get_config($componentname, $varname . '_lastindexrun'));
  113. // No caching.
  114. $configs = $search->get_areas_config(array($this->forumpostareaid => $searcharea));
  115. $this->assertEquals(0, $configs[$this->forumpostareaid]->indexingstart);
  116. $this->assertEquals(0, $configs[$this->forumpostareaid]->indexingend);
  117. }
  118. /**
  119. * Adding this test here as get_areas_user_accesses process is the same, results just depend on the context level.
  120. *
  121. * @return void
  122. */
  123. public function test_search_user_accesses() {
  124. global $DB;
  125. $this->resetAfterTest();
  126. $frontpage = $DB->get_record('course', array('id' => SITEID));
  127. $course1 = $this->getDataGenerator()->create_course();
  128. $course1ctx = context_course::instance($course1->id);
  129. $course2 = $this->getDataGenerator()->create_course();
  130. $course2ctx = context_course::instance($course2->id);
  131. $teacher = $this->getDataGenerator()->create_user();
  132. $teacherctx = context_user::instance($teacher->id);
  133. $student = $this->getDataGenerator()->create_user();
  134. $studentctx = context_user::instance($student->id);
  135. $noaccess = $this->getDataGenerator()->create_user();
  136. $noaccessctx = context_user::instance($noaccess->id);
  137. $this->getDataGenerator()->enrol_user($teacher->id, $course1->id, 'teacher');
  138. $this->getDataGenerator()->enrol_user($student->id, $course1->id, 'student');
  139. $frontpageforum = $this->getDataGenerator()->create_module('forum', array('course' => $frontpage->id));
  140. $forum1 = $this->getDataGenerator()->create_module('forum', array('course' => $course1->id));
  141. $forum2 = $this->getDataGenerator()->create_module('forum', array('course' => $course1->id));
  142. $forum3 = $this->getDataGenerator()->create_module('forum', array('course' => $course2->id));
  143. $frontpageforumcontext = context_module::instance($frontpageforum->cmid);
  144. $context1 = context_module::instance($forum1->cmid);
  145. $context2 = context_module::instance($forum2->cmid);
  146. $context3 = context_module::instance($forum3->cmid);
  147. $search = testable_core_search::instance();
  148. $mockareaid = \core_search\manager::generate_areaid('core_mocksearch', 'mock_search_area');
  149. $search->add_core_search_areas();
  150. $search->add_search_area($mockareaid, new core_mocksearch\search\mock_search_area());
  151. $this->setAdminUser();
  152. $this->assertTrue($search->get_areas_user_accesses());
  153. $sitectx = \context_course::instance(SITEID);
  154. $systemctxid = \context_system::instance()->id;
  155. // Can access the frontpage ones.
  156. $this->setUser($noaccess);
  157. $contexts = $search->get_areas_user_accesses();
  158. $this->assertEquals(array($frontpageforumcontext->id => $frontpageforumcontext->id), $contexts[$this->forumpostareaid]);
  159. $this->assertEquals(array($sitectx->id => $sitectx->id), $contexts[$this->mycoursesareaid]);
  160. $mockctxs = array($noaccessctx->id => $noaccessctx->id, $systemctxid => $systemctxid);
  161. $this->assertEquals($mockctxs, $contexts[$mockareaid]);
  162. $this->setUser($teacher);
  163. $contexts = $search->get_areas_user_accesses();
  164. $frontpageandcourse1 = array($frontpageforumcontext->id => $frontpageforumcontext->id, $context1->id => $context1->id,
  165. $context2->id => $context2->id);
  166. $this->assertEquals($frontpageandcourse1, $contexts[$this->forumpostareaid]);
  167. $this->assertEquals(array($sitectx->id => $sitectx->id, $course1ctx->id => $course1ctx->id),
  168. $contexts[$this->mycoursesareaid]);
  169. $mockctxs = array($teacherctx->id => $teacherctx->id, $systemctxid => $systemctxid);
  170. $this->assertEquals($mockctxs, $contexts[$mockareaid]);
  171. $this->setUser($student);
  172. $contexts = $search->get_areas_user_accesses();
  173. $this->assertEquals($frontpageandcourse1, $contexts[$this->forumpostareaid]);
  174. $this->assertEquals(array($sitectx->id => $sitectx->id, $course1ctx->id => $course1ctx->id),
  175. $contexts[$this->mycoursesareaid]);
  176. $mockctxs = array($studentctx->id => $studentctx->id, $systemctxid => $systemctxid);
  177. $this->assertEquals($mockctxs, $contexts[$mockareaid]);
  178. // Hide the activity.
  179. set_coursemodule_visible($forum2->cmid, 0);
  180. $contexts = $search->get_areas_user_accesses();
  181. $this->assertEquals(array($frontpageforumcontext->id => $frontpageforumcontext->id, $context1->id => $context1->id),
  182. $contexts[$this->forumpostareaid]);
  183. // Now test course limited searches.
  184. set_coursemodule_visible($forum2->cmid, 1);
  185. $this->getDataGenerator()->enrol_user($student->id, $course2->id, 'student');
  186. $contexts = $search->get_areas_user_accesses();
  187. $allcontexts = array($frontpageforumcontext->id => $frontpageforumcontext->id, $context1->id => $context1->id,
  188. $context2->id => $context2->id, $context3->id => $context3->id);
  189. $this->assertEquals($allcontexts, $contexts[$this->forumpostareaid]);
  190. $this->assertEquals(array($sitectx->id => $sitectx->id, $course1ctx->id => $course1ctx->id,
  191. $course2ctx->id => $course2ctx->id), $contexts[$this->mycoursesareaid]);
  192. $contexts = $search->get_areas_user_accesses(array($course1->id, $course2->id));
  193. $allcontexts = array($context1->id => $context1->id, $context2->id => $context2->id, $context3->id => $context3->id);
  194. $this->assertEquals($allcontexts, $contexts[$this->forumpostareaid]);
  195. $this->assertEquals(array($course1ctx->id => $course1ctx->id,
  196. $course2ctx->id => $course2ctx->id), $contexts[$this->mycoursesareaid]);
  197. $contexts = $search->get_areas_user_accesses(array($course2->id));
  198. $allcontexts = array($context3->id => $context3->id);
  199. $this->assertEquals($allcontexts, $contexts[$this->forumpostareaid]);
  200. $this->assertEquals(array($course2ctx->id => $course2ctx->id), $contexts[$this->mycoursesareaid]);
  201. $contexts = $search->get_areas_user_accesses(array($course1->id));
  202. $allcontexts = array($context1->id => $context1->id, $context2->id => $context2->id);
  203. $this->assertEquals($allcontexts, $contexts[$this->forumpostareaid]);
  204. $this->assertEquals(array($course1ctx->id => $course1ctx->id), $contexts[$this->mycoursesareaid]);
  205. }
  206. /**
  207. * test_is_search_area
  208. *
  209. * @return void
  210. */
  211. public function test_is_search_area() {
  212. $this->assertFalse(testable_core_search::is_search_area('\asd\asd'));
  213. $this->assertFalse(testable_core_search::is_search_area('\mod_forum\search\posta'));
  214. $this->assertFalse(testable_core_search::is_search_area('\core_search\base_mod'));
  215. $this->assertTrue(testable_core_search::is_search_area('\mod_forum\search\post'));
  216. $this->assertTrue(testable_core_search::is_search_area('\\mod_forum\\search\\post'));
  217. $this->assertTrue(testable_core_search::is_search_area('mod_forum\\search\\post'));
  218. }
  219. }