See Release Notes
Long Term Support Release
Differences Between: [Versions 39 and 311] [Versions 39 and 400] [Versions 39 and 401] [Versions 39 and 402] [Versions 39 and 403]
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 autocomplete forms element. 19 * 20 * This file contains all unit test related to autocomplete forms element. 21 * 22 * @package core_form 23 * @copyright 2015 Damyon Wiese <damyon@moodle.com> 24 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 25 */ 26 27 defined('MOODLE_INTERNAL') || die(); 28 29 global $CFG; 30 require_once($CFG->libdir . '/form/autocomplete.php'); 31 32 /** 33 * Unit tests for MoodleQuickForm_autocomplete 34 * 35 * Contains test cases for testing MoodleQuickForm_autocomplete 36 * 37 * @package core_form 38 * @copyright 2015 Damyon Wiese <damyon@moodle.com> 39 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 40 */ 41 class core_form_autocomplete_testcase extends basic_testcase { 42 /** 43 * Testcase for validation 44 */ 45 public function test_validation() { 46 // A default select with single values validates the data. 47 $options = array('1' => 'One', 2 => 'Two'); 48 $element = new MoodleQuickForm_autocomplete('testel', null, $options); 49 $submission = array('testel' => 2); 50 $this->assertEquals($element->exportValue($submission), 2); 51 $submission = array('testel' => 3); 52 $this->assertEquals('', $element->exportValue($submission)); 53 54 // A select with multiple values validates the data. 55 $options = array('1' => 'One', 2 => 'Two'); 56 $element = new MoodleQuickForm_autocomplete('testel', null, $options, array('multiple'=>'multiple')); 57 $submission = array('testel' => array(2, 3)); 58 $this->assertEquals($element->exportValue($submission), array(2)); 59 60 // A select where the values are fetched via ajax does not validate the data. 61 $element = new MoodleQuickForm_autocomplete('testel', null, array(), array('multiple'=>'multiple', 'ajax'=>'anything')); 62 $submission = array('testel' => array(2, 3)); 63 $this->assertEquals($element->exportValue($submission), array(2, 3)); 64 65 // A select with single value without anything selected. 66 $options = array('1' => 'One', 2 => 'Two'); 67 $element = new MoodleQuickForm_autocomplete('testel', null, $options); 68 $submission = array(); 69 $this->assertEquals('', $element->exportValue($submission)); 70 71 // A select with multiple values without anything selected. 72 $options = array('1' => 'One', 2 => 'Two'); 73 $element = new MoodleQuickForm_autocomplete('testel', null, $options, array('multiple' => 'multiple')); 74 $submission = array(); 75 $this->assertEquals([], $element->exportValue($submission)); 76 } 77 78 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body