Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.11.x will end 14 Nov 2022 (12 months plus 6 months extension).
  • Bug fixes for security issues in 3.11.x will end 13 Nov 2023 (18 months plus 12 months extension).
  • PHP version: minimum PHP 7.3.0 Note: minimum PHP version has increased since Moodle 3.10. PHP 7.4.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/>.

< /** < * Unit tests for autocomplete forms element. < * < * This file contains all unit test related to autocomplete forms element. < * < * @package core_form < * @copyright 2015 Damyon Wiese <damyon@moodle.com> < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */
> namespace core_form; > > use MoodleQuickForm_autocomplete;
defined('MOODLE_INTERNAL') || die(); global $CFG; require_once($CFG->libdir . '/form/autocomplete.php'); /** * Unit tests for MoodleQuickForm_autocomplete * * Contains test cases for testing MoodleQuickForm_autocomplete * * @package core_form * @copyright 2015 Damyon Wiese <damyon@moodle.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class core_form_autocomplete_testcase extends basic_testcase {
> class autocomplete_test extends \basic_testcase {
/** * Testcase for validation */ public function test_validation() { // A default select with single values validates the data. $options = array('1' => 'One', 2 => 'Two'); $element = new MoodleQuickForm_autocomplete('testel', null, $options); $submission = array('testel' => 2); $this->assertEquals($element->exportValue($submission), 2); $submission = array('testel' => 3); $this->assertEquals('', $element->exportValue($submission)); // A select with multiple values validates the data. $options = array('1' => 'One', 2 => 'Two'); $element = new MoodleQuickForm_autocomplete('testel', null, $options, array('multiple'=>'multiple')); $submission = array('testel' => array(2, 3)); $this->assertEquals($element->exportValue($submission), array(2)); // A select where the values are fetched via ajax does not validate the data. $element = new MoodleQuickForm_autocomplete('testel', null, array(), array('multiple'=>'multiple', 'ajax'=>'anything')); $submission = array('testel' => array(2, 3)); $this->assertEquals($element->exportValue($submission), array(2, 3)); // A select with single value without anything selected. $options = array('1' => 'One', 2 => 'Two'); $element = new MoodleQuickForm_autocomplete('testel', null, $options); $submission = array(); $this->assertEquals('', $element->exportValue($submission)); // A select with multiple values without anything selected. $options = array('1' => 'One', 2 => 'Two'); $element = new MoodleQuickForm_autocomplete('testel', null, $options, array('multiple' => 'multiple')); $submission = array(); $this->assertEquals([], $element->exportValue($submission)); } }