Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 3.9.x will end* 10 May 2021 (12 months).
  • Bug fixes for security issues in 3.9.x will end* 8 May 2023 (36 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are 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/classes/output/mustache_template_finder.php
 *
 * @package   core
 * @category  phpunit
 * @copyright 2015 Damyon Wiese
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

defined('MOODLE_INTERNAL') || die();

use core\output\mustache_template_finder;

/**
 * Unit tests for the Mustache template finder class (contains logic about
 * resolving mustache template locations.
 */
class core_output_mustache_template_finder_testcase extends advanced_testcase {

    /**
     * Data provider which reutrns a set of valid template directories to be used when testing
     * get_template_directories_for_component.
     *
     * @return array
     */
    public function valid_template_directories_provider(): array {
        return [
            'plugin: mod_assign' => [
                'component' => 'mod_assign',
                'theme' => '',
                'paths' => [
                    'theme/boost/templates/mod_assign/',
                    'mod/assign/templates/'
                ],
            ],
            'plugin: mod_assign with classic' => [
                'component' => 'mod_assign',
                'theme' => 'classic',
                'paths' => [
                    'theme/classic/templates/mod_assign/',
                    'theme/boost/templates/mod_assign/',
                    'mod/assign/templates/'
                ],
            ],
            'subsystem: core_user' => [
                'component' => 'core_user',
                'theme' => 'classic',
                'paths' => [
                    'theme/classic/templates/core_user/',
                    'theme/boost/templates/core_user/',
                    'user/templates/'
                ],
            ],
            'core' => [
                'component' => 'core',
                'theme' => 'classic',
                'paths' => [
                    'theme/classic/templates/core/',
                    'theme/boost/templates/core/',
                    'lib/templates/'
                ],
            ],
        ];
    }

    /**
     * Tests for get_template_directories_for_component.
     *
     * @dataProvider valid_template_directories_provider
     * @param   string $component
     * @param   string $theme
     * @param   array $paths
     */
    public function test_get_template_directories_for_component(string $component, string $theme, array $paths): void {
        global $CFG;

        // Test a plugin.
        $dirs = mustache_template_finder::get_template_directories_for_component($component, $theme, $paths);

        $correct = array_map(function($path) use ($CFG) {
            return implode('/', [$CFG->dirroot, $path]);
        }, $paths);

        $this->assertEquals($correct, $dirs);
    }

    /**
     * Tests for get_template_directories_for_component when dealing with an invalid component.
< * < * @expectedException coding_exception
*/ public function test_invalid_component_get_template_directories_for_component() { // Test something invalid.
> $this->expectException(coding_exception::class);
mustache_template_finder::get_template_directories_for_component('octopus', 'classic'); } /** * Data provider which reutrns a set of valid template directories to be used when testing * get_template_directories_for_component. * * @return array */ public function valid_template_filepath_provider(): array { return [ 'Standard core template' => [ 'template' => 'core/modal', 'theme' => '', 'location' => 'lib/templates/modal.mustache', ], 'Template overridden by theme' => [ 'template' => 'core_form/element-float-inline', 'theme' => '', 'location' => 'theme/boost/templates/core_form/element-float-inline.mustache', ], 'Template overridden by theme but child theme selected' => [ 'template' => 'core_form/element-float-inline', 'theme' => 'classic', 'location' => 'theme/boost/templates/core_form/element-float-inline.mustache', ], 'Template overridden by child theme' => [ 'template' => 'core/full_header', 'theme' => 'classic', 'location' => 'theme/classic/templates/core/full_header.mustache', ], 'Template overridden by child theme but tested against defualt theme' => [ 'template' => 'core/full_header', 'theme' => '', 'location' => 'lib/templates/full_header.mustache', ], 'Standard plugin template' => [ 'template' => 'mod_assign/grading_panel', 'theme' => '', 'location' => 'mod/assign/templates/grading_panel.mustache', ], 'Subsystem template' => [ 'template' => 'core_user/status_details', 'theme' => '', 'location' => 'user/templates/status_details.mustache', ], 'Theme own template' => [ 'template' => 'theme_classic/columns', 'theme' => '', 'location' => 'theme/classic/templates/columns.mustache', ], 'Theme overridden template against that theme' => [ 'template' => 'theme_classic/navbar', 'theme' => 'classic', 'location' => 'theme/classic/templates/navbar.mustache', ], // Note: This one looks strange but is correct. It is legitimate to request theme's component template in // the context of another theme. For example, this is used by child themes making use of parent theme // templates. 'Theme overridden template against the default theme' => [ 'template' => 'theme_classic/navbar', 'theme' => '', 'location' => 'theme/classic/templates/navbar.mustache', ], ]; } /** * Tests for get_template_filepath. * * @dataProvider valid_template_filepath_provider * @param string $template * @param string $theme * @param string $location */ public function test_get_template_filepath(string $template, string $theme, string $location) { global $CFG; $filename = mustache_template_finder::get_template_filepath($template, $theme); $this->assertEquals("{$CFG->dirroot}/{$location}", $filename); } /** * Tests for get_template_filepath when dealing with an invalid component.
< * < * @expectedException moodle_exception
*/ public function test_invalid_component_get_template_filepath() {
> $this->expectException(moodle_exception::class);
mustache_template_finder::get_template_filepath('core/octopus', 'classic'); } }