See Release Notes
Long Term Support Release
<?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 lib/outputrequirementslibphp. < * < * @package core < * @category phpunit < * @copyright 2012 Petr Škoda < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */> namespace core;defined('MOODLE_INTERNAL') || die(); global $CFG; require_once($CFG->libdir . '/outputrequirementslib.php');< class core_outputrequirementslib_testcase extends advanced_testcase {> /** > * Unit tests for lib/outputrequirementslibphp. > * > * @package core > * @category test > * @copyright 2012 Petr Škoda > * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later > */ > class outputrequirementslib_test extends \advanced_testcase {public function test_string_for_js() { $this->resetAfterTest();< $page = new moodle_page();> $page = new \moodle_page();$page->requires->string_for_js('course', 'moodle', 1); $page->requires->string_for_js('course', 'moodle', 1); $this->expectException('coding_exception'); $page->requires->string_for_js('course', 'moodle', 2); // Note: we can not switch languages in phpunit yet, // it would be nice to test that the strings are actually fetched in the footer. } public function test_one_time_output_normal_case() {< $page = new moodle_page();> $page = new \moodle_page();$this->assertTrue($page->requires->should_create_one_time_item_now('test_item')); $this->assertFalse($page->requires->should_create_one_time_item_now('test_item')); } public function test_one_time_output_repeat_output_throws() {< $page = new moodle_page();> $page = new \moodle_page();$page->requires->set_one_time_item_created('test_item'); $this->expectException('coding_exception'); $page->requires->set_one_time_item_created('test_item'); } public function test_one_time_output_different_pages_independent() {< $firstpage = new moodle_page(); < $secondpage = new moodle_page();> $firstpage = new \moodle_page(); > $secondpage = new \moodle_page();$this->assertTrue($firstpage->requires->should_create_one_time_item_now('test_item')); $this->assertTrue($secondpage->requires->should_create_one_time_item_now('test_item')); } /** * Test for the jquery_plugin method. * * Test to make sure that backslashes are not generated with either slasharguments set to on or off. */ public function test_jquery_plugin() { global $CFG, $PAGE; $this->resetAfterTest(); // With slasharguments on. $CFG->slasharguments = 1;< $page = new moodle_page();> $page = new \moodle_page();$requirements = $page->requires; // Assert successful method call. $this->assertTrue($requirements->jquery_plugin('jquery')); $this->assertTrue($requirements->jquery_plugin('ui')); // Get the code containing the required jquery plugins. $renderer = $PAGE->get_renderer('core', null, RENDERER_TARGET_MAINTENANCE); $requirecode = $requirements->get_top_of_body_code($renderer); // Make sure that the generated code does not contain backslashes. $this->assertFalse(strpos($requirecode, '\\'), "Output contains backslashes: " . $requirecode); // With slasharguments off. $CFG->slasharguments = 0;< $page = new moodle_page();> $page = new \moodle_page();$requirements = $page->requires; // Assert successful method call. $this->assertTrue($requirements->jquery_plugin('jquery')); $this->assertTrue($requirements->jquery_plugin('ui')); // Get the code containing the required jquery plugins. $requirecode = $requirements->get_top_of_body_code($renderer); // Make sure that the generated code does not contain backslashes. $this->assertFalse(strpos($requirecode, '\\'), "Output contains backslashes: " . $requirecode); } /** * Test AMD modules loading. */ public function test_js_call_amd() {< $page = new moodle_page();> $page = new \moodle_page();// Load an AMD module without a function call. $page->requires->js_call_amd('theme_foobar/lightbox'); // Load an AMD module and call its function without parameters. $page->requires->js_call_amd('theme_foobar/demo_one', 'init'); // Load an AMD module and call its function with some parameters. $page->requires->js_call_amd('theme_foobar/demo_two', 'init', [ 'foo', 'keyWillIgnored' => 'baz', [42, 'xyz'], ]); $html = $page->requires->get_end_code(); $modname = 'theme_foobar/lightbox'; $this->assertStringContainsString("M.util.js_pending('{$modname}'); require(['{$modname}'], function(amd) {M.util.js_complete('{$modname}');});", $html); $modname = 'theme_foobar/demo_one'; $this->assertStringContainsString("M.util.js_pending('{$modname}'); require(['{$modname}'], function(amd) {amd.init(); M.util.js_complete('{$modname}');});", $html); $modname = 'theme_foobar/demo_two'; $this->assertStringContainsString("M.util.js_pending('{$modname}'); require(['{$modname}'], function(amd) {amd.init(\"foo\", \"baz\", [42,\"xyz\"]); M.util.js_complete('{$modname}');});", $html); } }