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/>.

< /** < * 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); } }