Merge branch 'MDL-73457-master-2' of https://github.com/HuongNV13/moodle
[moodle.git] / question / tests / bank_view_test.php
blobd1dfc0556a9d024af0de51620049466352413f90
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.
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/>.
17 /**
18 * Unit tests for the question bank view class.
20 * @package core_question
21 * @category test
22 * @copyright 2018 the Open University
23 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
26 defined('MOODLE_INTERNAL') || die();
28 global $CFG;
29 require_once($CFG->dirroot . '/question/editlib.php');
32 /**
33 * Unit tests for the question bank view class.
35 * @copyright 2018 the Open University
36 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
38 class core_question_bank_view_testcase extends advanced_testcase {
40 public function test_viewing_question_bank_should_not_load_individual_questions() {
41 $this->resetAfterTest();
42 $this->setAdminUser();
43 $generator = $this->getDataGenerator();
44 /** @var core_question_generator $questiongenerator */
45 $questiongenerator = $generator->get_plugin_generator('core_question');
47 // Create a course.
48 $course = $generator->create_course();
49 $context = context_course::instance($course->id);
51 // Create a question in the default category.
52 $contexts = new core_question\local\bank\question_edit_contexts($context);
53 $cat = question_make_default_categories($contexts->all());
54 $questiondata = $questiongenerator->create_question('numerical', null,
55 ['name' => 'Example question', 'category' => $cat->id]);
57 // Ensure the question is not in the cache.
58 $cache = cache::make('core', 'questiondata');
59 $cache->delete($questiondata->id);
61 // Generate the view.
62 $view = new core_question\local\bank\view($contexts, new moodle_url('/'), $course);
63 ob_start();
64 $pagevars = [
65 'qpage' => 0,
66 'qperpage' => 20,
67 'cat' => $cat->id . ',' . $context->id,
68 'recurse' => false,
69 'showhidden' => false,
70 'qbshowtext' => false
73 $view->display($pagevars, 'editq');
74 $html = ob_get_clean();
76 // Verify the output includes the expected question.
77 $this->assertStringContainsString('Example question', $html);
79 // Verify the question has not been loaded into the cache.
80 $this->assertFalse($cache->has($questiondata->id));
83 public function test_unknown_qtype_does_not_break_view() {
84 global $DB;
85 $this->resetAfterTest();
86 $this->setAdminUser();
87 $generator = $this->getDataGenerator();
88 /** @var core_question_generator $questiongenerator */
89 $questiongenerator = $generator->get_plugin_generator('core_question');
91 // Create a course.
92 $course = $generator->create_course();
93 $context = context_course::instance($course->id);
95 // Create a question in the default category.
96 $contexts = new core_question\local\bank\question_edit_contexts($context);
97 $cat = question_make_default_categories($contexts->all());
98 $questiondata = $questiongenerator->create_question('numerical', null,
99 ['name' => 'Example question', 'category' => $cat->id]);
100 $DB->set_field('question', 'qtype', 'unknownqtype', ['id' => $questiondata->id]);
102 // Generate the view.
103 $view = new core_question\local\bank\view($contexts, new moodle_url('/'), $course);
104 ob_start();
105 $pagevars = [
106 'qpage' => 0,
107 'qperpage' => 20,
108 'cat' => $cat->id . ',' . $context->id,
109 'recurse' => false,
110 'showhidden' => false,
111 'qbshowtext' => false
114 $view->display($pagevars, 'editq');
115 $html = ob_get_clean();
117 // Mainly we are verifying that there was no fatal error.
119 // Verify the output includes the expected question.
120 $this->assertStringContainsString('Example question', $html);