Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 4.1.x will end 13 November 2023 (12 months).
  • Bug fixes for security issues in 4.1.x will end 10 November 2025 (36 months).
  • PHP version: minimum PHP 7.4.0 Note: minimum PHP version has increased since Moodle 4.0. PHP 8.0.x is supported too.
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

< /** < * This file contains tests for the question_attempt class. < * < * Action methods like start, process_action and finish are assumed to be < * tested by walkthrough tests in the various behaviours. < * < * @package moodlecore < * @subpackage questionengine < * @copyright 2009 The Open University < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */
> namespace core_question;
> use question_attempt;
defined('MOODLE_INTERNAL') || die(); global $CFG; require_once(__DIR__ . '/../lib.php'); require_once(__DIR__ . '/helpers.php');
<
/** * Unit tests for the {@link question_attempt} class. *
> * Action methods like start, process_action and finish are assumed to be * These are the tests that don't require any steps. > * tested by walkthrough tests in the various behaviours. * > *
* @copyright 2009 The Open University
> * @package core_question * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later > * @category test
*/
< class question_attempt_testcase extends advanced_testcase {
> class questionattempt_test extends \advanced_testcase {
/** @var question_definition a question that can be used in the tests. */ private $question; /** @var int fake question_usage id used in some tests. */ private $usageid; /** @var question_attempt a question attempt that can be used in the tests. */ private $qa; protected function setUp(): void {
< $this->question = test_question_maker::make_question('description');
> $this->question = \test_question_maker::make_question('description');
$this->question->defaultmark = 3; $this->usageid = 13; $this->qa = new question_attempt($this->question, $this->usageid); } protected function tearDown(): void { $this->question = null; $this->useageid = null; $this->qa = null; } public function test_constructor_sets_maxmark() { $qa = new question_attempt($this->question, $this->usageid); $this->assertSame($this->question, $qa->get_question(false)); $this->assertEquals(3, $qa->get_max_mark()); } public function test_maxmark_beats_default_mark() { $qa = new question_attempt($this->question, $this->usageid, null, 2); $this->assertEquals(2, $qa->get_max_mark()); } public function test_get_set_slot() { $this->qa->set_slot(7); $this->assertEquals(7, $this->qa->get_slot()); } public function test_fagged_initially_false() { $this->assertEquals(false, $this->qa->is_flagged()); } public function test_set_is_flagged() { $this->qa->set_flagged(true); $this->assertEquals(true, $this->qa->is_flagged()); } public function test_get_qt_field_name() { $name = $this->qa->get_qt_field_name('test');
< $this->assertRegExp('/^' . preg_quote($this->qa->get_field_prefix(), '/') . '/', $name); < $this->assertRegExp('/_test$/', $name);
> $this->assertMatchesRegularExpression('/^' . preg_quote($this->qa->get_field_prefix(), '/') . '/', $name); > $this->assertMatchesRegularExpression('/_test$/', $name);
} public function test_get_behaviour_field_name() { $name = $this->qa->get_behaviour_field_name('test');
< $this->assertRegExp('/^' . preg_quote($this->qa->get_field_prefix(), '/') . '/', $name); < $this->assertRegExp('/_-test$/', $name);
> $this->assertMatchesRegularExpression('/^' . preg_quote($this->qa->get_field_prefix(), '/') . '/', $name); > $this->assertMatchesRegularExpression('/_-test$/', $name);
} public function test_get_field_prefix() { $this->qa->set_slot(7); $name = $this->qa->get_field_prefix();
< $this->assertRegExp('/' . preg_quote($this->usageid, '/') . '/', $name); < $this->assertRegExp('/' . preg_quote($this->qa->get_slot(), '/') . '/', $name);
> $this->assertMatchesRegularExpression('/' . preg_quote($this->usageid, '/') . '/', $name); > $this->assertMatchesRegularExpression('/' . preg_quote($this->qa->get_slot(), '/') . '/', $name);
} public function test_get_submitted_var_not_present_var_returns_null() { $this->assertNull($this->qa->get_submitted_var( 'reallyunlikelyvariablename', PARAM_BOOL)); } public function test_get_all_submitted_qt_vars() { $this->qa->set_usage_id('MDOgzdhS4W'); $this->qa->set_slot(1); $this->assertEquals(array('omval_response1' => 1, 'omval_response2' => 666, 'omact_gen_14' => 'Check'), $this->qa->get_all_submitted_qt_vars(array( 'qMDOgzdhS4W:1_omval_response1' => 1, 'qMDOgzdhS4W:1_omval_response2' => 666, 'qMDOgzdhS4W:1_omact_gen_14' => 'Check', ))); } }