mirror of
https://github.com/moodle/moodle.git
synced 2025-01-18 22:08:20 +01:00
Merge branch 'MDL-55133-master' of git://github.com/damyon/moodle
This commit is contained in:
commit
7aad43e13f
@ -45,7 +45,7 @@ require_login($course);
|
|||||||
$context = context_course::instance($course->id);
|
$context = context_course::instance($course->id);
|
||||||
require_capability('moodle/grade:manage', $context);
|
require_capability('moodle/grade:manage', $context);
|
||||||
|
|
||||||
$PAGE->requires->js_call_amd('grades/edittree_index', 'enhance');
|
$PAGE->requires->js_call_amd('core_grades/edittree_index', 'enhance');
|
||||||
|
|
||||||
/// return tracking object
|
/// return tracking object
|
||||||
$gpr = new grade_plugin_return(array('type'=>'edit', 'plugin'=>'tree', 'courseid'=>$courseid));
|
$gpr = new grade_plugin_return(array('type'=>'edit', 'plugin'=>'tree', 'courseid'=>$courseid));
|
||||||
|
@ -90,7 +90,7 @@ class core_requirejs {
|
|||||||
$subsystems = core_component::get_core_subsystems();
|
$subsystems = core_component::get_core_subsystems();
|
||||||
foreach ($subsystems as $subsystem => $dir) {
|
foreach ($subsystems as $subsystem => $dir) {
|
||||||
if (!empty($dir) && is_dir($dir . '/amd')) {
|
if (!empty($dir) && is_dir($dir . '/amd')) {
|
||||||
$jsdirs[$subsystem] = $dir . '/amd';
|
$jsdirs['core_' . $subsystem] = $dir . '/amd';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$plugintypes = core_component::get_plugin_types();
|
$plugintypes = core_component::get_plugin_types();
|
||||||
|
95
lib/tests/requirejs_test.php
Normal file
95
lib/tests/requirejs_test.php
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
<?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 requirejs loader.
|
||||||
|
*
|
||||||
|
* @package core
|
||||||
|
* @author Damyon Wiese <damyon@moodle.com>
|
||||||
|
* @copyright 2016 Damyon Wiese
|
||||||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||||
|
*/
|
||||||
|
|
||||||
|
defined('MOODLE_INTERNAL') || die();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Unit tests for requirejs.
|
||||||
|
*
|
||||||
|
* @package core
|
||||||
|
* @author Damyon Wiese <damyon@moodle.com>
|
||||||
|
* @copyright 2016 Damyon Wiese
|
||||||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||||
|
*/
|
||||||
|
class core_requirejs_testcase extends advanced_testcase {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test requirejs loader
|
||||||
|
*/
|
||||||
|
public function test_requirejs() {
|
||||||
|
global $CFG;
|
||||||
|
|
||||||
|
// Find a core module.
|
||||||
|
$result = core_requirejs::find_one_amd_module('core', 'templates', false);
|
||||||
|
$expected = ['core/templates' => $CFG->dirroot . '/lib/amd/build/templates.min.js'];
|
||||||
|
$this->assertEquals($expected, $result);
|
||||||
|
|
||||||
|
$result = core_requirejs::find_one_amd_module('core', 'templates', true);
|
||||||
|
$expected = ['core/templates' => $CFG->dirroot . '/lib/amd/src/templates.js'];
|
||||||
|
$this->assertEquals($expected, $result);
|
||||||
|
|
||||||
|
// Find a subsystem module (none exist yet).
|
||||||
|
$result = core_requirejs::find_one_amd_module('core_group', 'doesnotexist', false);
|
||||||
|
$expected = [];
|
||||||
|
$this->assertEquals($expected, $result);
|
||||||
|
|
||||||
|
// Find a plugin module.
|
||||||
|
$result = core_requirejs::find_one_amd_module('mod_assign', 'grading_panel', true);
|
||||||
|
$expected = ['mod_assign/grading_panel' => $CFG->dirroot . '/mod/assign/amd/src/grading_panel.js'];
|
||||||
|
$this->assertEquals($expected, $result);
|
||||||
|
|
||||||
|
// Find all modules - no debugging.
|
||||||
|
$result = core_requirejs::find_all_amd_modules(true);
|
||||||
|
foreach ($result as $key => $path) {
|
||||||
|
// Lets verify the first part of the key is a valid component name and the second part correctly contains "min" or not.
|
||||||
|
list($component, $template) = explode('/', $key, 2);
|
||||||
|
// Can we resolve it to a valid dir?
|
||||||
|
$dir = core_component::get_component_directory($component);
|
||||||
|
$this->assertNotEmpty($dir);
|
||||||
|
|
||||||
|
// Only "core" is allowed to have no _ in component names.
|
||||||
|
if (strpos($component, '_') === false) {
|
||||||
|
$this->assertEquals('core', $component);
|
||||||
|
}
|
||||||
|
$this->assertNotContains('.min', $path);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find all modules - debugging.
|
||||||
|
$result = core_requirejs::find_all_amd_modules(false);
|
||||||
|
foreach ($result as $key => $path) {
|
||||||
|
// Lets verify the first part of the key is a valid component name and the second part correctly contains "min" or not.
|
||||||
|
list($component, $template) = explode('/', $key, 2);
|
||||||
|
$dir = core_component::get_component_directory($component);
|
||||||
|
$this->assertNotEmpty($dir);
|
||||||
|
// Only "core" is allowed to have no _ in component names.
|
||||||
|
if (strpos($component, '_') === false) {
|
||||||
|
$this->assertEquals('core', $component);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->assertContains('.min', $path);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user