See Release Notes
Long Term Support Release
Differences Between: [Versions 39 and 310]
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 /** 18 * Unit tests for the description question type class. 19 * 20 * @package qtype_description 21 * @copyright 2013 The Open University 22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 23 */ 24 25 26 defined('MOODLE_INTERNAL') || die(); 27 28 global $CFG; 29 require_once($CFG->dirroot . '/question/type/description/questiontype.php'); 30 require_once($CFG->dirroot . '/question/engine/tests/helpers.php'); 31 require_once($CFG->dirroot . '/question/type/edit_question_form.php'); 32 require_once($CFG->dirroot . '/question/type/description/edit_description_form.php'); 33 34 35 /** 36 * Unit tests for the description question type class. 37 * 38 * @copyright 2013 The Open University 39 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 40 */ 41 class qtype_description_test extends advanced_testcase { 42 protected $qtype; 43 44 protected function setUp() { 45 $this->qtype = new qtype_description(); 46 } 47 48 protected function tearDown() { 49 $this->qtype = null; 50 } 51 52 public function test_name() { 53 $this->assertEquals($this->qtype->name(), 'description'); 54 } 55 56 public function test_actual_number_of_questions() { 57 $this->assertEquals(0, $this->qtype->actual_number_of_questions(null)); 58 } 59 60 public function test_can_analyse_responses() { 61 $this->assertFalse($this->qtype->can_analyse_responses()); 62 } 63 64 public function test_get_random_guess_score() { 65 $this->assertNull($this->qtype->get_random_guess_score(null)); 66 } 67 68 public function test_get_possible_responses() { 69 $this->assertEquals(array(), $this->qtype->get_possible_responses(null)); 70 } 71 72 73 public function test_question_saving() { 74 $this->resetAfterTest(true); 75 $this->setAdminUser(); 76 77 $questiondata = test_question_maker::get_question_data('description'); 78 $formdata = test_question_maker::get_question_form_data('description'); 79 80 $generator = $this->getDataGenerator()->get_plugin_generator('core_question'); 81 $cat = $generator->create_question_category(array()); 82 83 $formdata->category = "{$cat->id},{$cat->contextid}"; 84 qtype_description_edit_form::mock_submit((array)$formdata); 85 86 $form = qtype_description_test_helper::get_question_editing_form($cat, $questiondata); 87 88 $this->assertTrue($form->is_validated()); 89 90 $fromform = $form->get_data(); 91 92 $returnedfromsave = $this->qtype->save_question($questiondata, $fromform); 93 $actualquestionsdata = question_load_questions(array($returnedfromsave->id)); 94 $actualquestiondata = end($actualquestionsdata); 95 96 foreach ($questiondata as $property => $value) { 97 if (!in_array($property, array('id', 'version', 'timemodified', 'timecreated'))) { 98 $this->assertAttributeEquals($value, $property, $actualquestiondata); 99 } 100 } 101 } 102 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body