See Release Notes
Long Term Support Release
Differences Between: [Versions 39 and 310]
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 lib/classes/output/mustache_template_finder.php 19 * 20 * @package core 21 * @category phpunit 22 * @copyright 2015 Damyon Wiese 23 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 24 */ 25 26 defined('MOODLE_INTERNAL') || die(); 27 28 use core\output\mustache_template_finder; 29 30 /** 31 * Unit tests for the Mustache template finder class (contains logic about 32 * resolving mustache template locations. 33 */ 34 class core_output_mustache_template_finder_testcase extends advanced_testcase { 35 36 /** 37 * Data provider which reutrns a set of valid template directories to be used when testing 38 * get_template_directories_for_component. 39 * 40 * @return array 41 */ 42 public function valid_template_directories_provider(): array { 43 return [ 44 'plugin: mod_assign' => [ 45 'component' => 'mod_assign', 46 'theme' => '', 47 'paths' => [ 48 'theme/boost/templates/mod_assign/', 49 'mod/assign/templates/' 50 ], 51 ], 52 'plugin: mod_assign with classic' => [ 53 'component' => 'mod_assign', 54 'theme' => 'classic', 55 'paths' => [ 56 'theme/classic/templates/mod_assign/', 57 'theme/boost/templates/mod_assign/', 58 'mod/assign/templates/' 59 ], 60 ], 61 'subsystem: core_user' => [ 62 'component' => 'core_user', 63 'theme' => 'classic', 64 'paths' => [ 65 'theme/classic/templates/core_user/', 66 'theme/boost/templates/core_user/', 67 'user/templates/' 68 ], 69 ], 70 'core' => [ 71 'component' => 'core', 72 'theme' => 'classic', 73 'paths' => [ 74 'theme/classic/templates/core/', 75 'theme/boost/templates/core/', 76 'lib/templates/' 77 ], 78 ], 79 ]; 80 } 81 82 /** 83 * Tests for get_template_directories_for_component. 84 * 85 * @dataProvider valid_template_directories_provider 86 * @param string $component 87 * @param string $theme 88 * @param array $paths 89 */ 90 public function test_get_template_directories_for_component(string $component, string $theme, array $paths): void { 91 global $CFG; 92 93 // Test a plugin. 94 $dirs = mustache_template_finder::get_template_directories_for_component($component, $theme, $paths); 95 96 $correct = array_map(function($path) use ($CFG) { 97 return implode('/', [$CFG->dirroot, $path]); 98 }, $paths); 99 100 $this->assertEquals($correct, $dirs); 101 } 102 103 /** 104 * Tests for get_template_directories_for_component when dealing with an invalid component. 105 * 106 * @expectedException coding_exception 107 */ 108 public function test_invalid_component_get_template_directories_for_component() { 109 // Test something invalid. 110 mustache_template_finder::get_template_directories_for_component('octopus', 'classic'); 111 } 112 113 /** 114 * Data provider which reutrns a set of valid template directories to be used when testing 115 * get_template_directories_for_component. 116 * 117 * @return array 118 */ 119 public function valid_template_filepath_provider(): array { 120 return [ 121 'Standard core template' => [ 122 'template' => 'core/modal', 123 'theme' => '', 124 'location' => 'lib/templates/modal.mustache', 125 ], 126 'Template overridden by theme' => [ 127 'template' => 'core_form/element-float-inline', 128 'theme' => '', 129 'location' => 'theme/boost/templates/core_form/element-float-inline.mustache', 130 ], 131 'Template overridden by theme but child theme selected' => [ 132 'template' => 'core_form/element-float-inline', 133 'theme' => 'classic', 134 'location' => 'theme/boost/templates/core_form/element-float-inline.mustache', 135 ], 136 'Template overridden by child theme' => [ 137 'template' => 'core/full_header', 138 'theme' => 'classic', 139 'location' => 'theme/classic/templates/core/full_header.mustache', 140 ], 141 'Template overridden by child theme but tested against defualt theme' => [ 142 'template' => 'core/full_header', 143 'theme' => '', 144 'location' => 'lib/templates/full_header.mustache', 145 ], 146 'Standard plugin template' => [ 147 'template' => 'mod_assign/grading_panel', 148 'theme' => '', 149 'location' => 'mod/assign/templates/grading_panel.mustache', 150 ], 151 'Subsystem template' => [ 152 'template' => 'core_user/status_details', 153 'theme' => '', 154 'location' => 'user/templates/status_details.mustache', 155 ], 156 'Theme own template' => [ 157 'template' => 'theme_classic/columns', 158 'theme' => '', 159 'location' => 'theme/classic/templates/columns.mustache', 160 ], 161 'Theme overridden template against that theme' => [ 162 'template' => 'theme_classic/navbar', 163 'theme' => 'classic', 164 'location' => 'theme/classic/templates/navbar.mustache', 165 ], 166 // Note: This one looks strange but is correct. It is legitimate to request theme's component template in 167 // the context of another theme. For example, this is used by child themes making use of parent theme 168 // templates. 169 'Theme overridden template against the default theme' => [ 170 'template' => 'theme_classic/navbar', 171 'theme' => '', 172 'location' => 'theme/classic/templates/navbar.mustache', 173 ], 174 ]; 175 } 176 177 /** 178 * Tests for get_template_filepath. 179 * 180 * @dataProvider valid_template_filepath_provider 181 * @param string $template 182 * @param string $theme 183 * @param string $location 184 */ 185 public function test_get_template_filepath(string $template, string $theme, string $location) { 186 global $CFG; 187 188 $filename = mustache_template_finder::get_template_filepath($template, $theme); 189 $this->assertEquals("{$CFG->dirroot}/{$location}", $filename); 190 } 191 192 /** 193 * Tests for get_template_filepath when dealing with an invalid component. 194 * 195 * @expectedException moodle_exception 196 */ 197 public function test_invalid_component_get_template_filepath() { 198 mustache_template_finder::get_template_filepath('core/octopus', 'classic'); 199 } 200 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body