HEX
Server: Apache/2
System: Linux deejung.jaideehosting.com 3.10.0-693.17.1.el7.x86_64 #1 SMP Thu Jan 25 20:13:58 UTC 2018 x86_64
User: mbp (1631)
PHP: 7.4.15
Disabled: NONE
Upload Files
File: /home/mbp/domains/mbp.ac.th/public_html/biology/lib/tests/mustache_template_finder_test.php
<?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 {

    public function test_get_template_directories_for_component() {
        global $CFG;

        // Test a plugin.
        $dirs = mustache_template_finder::get_template_directories_for_component('mod_assign', 'clean');

        $correct = array(
            'theme/clean/templates/mod_assign/',
            'theme/bootstrapbase/templates/mod_assign/',
            'mod/assign/templates/'
        );
        foreach ($dirs as $index => $dir) {
            $this->assertSame($dir, $CFG->dirroot . '/' . $correct[$index]);
        }
        // Test a subsystem.
        $dirs = mustache_template_finder::get_template_directories_for_component('core_user', 'clean');

        $correct = array(
            'theme/clean/templates/core_user/',
            'theme/bootstrapbase/templates/core_user/',
            'user/templates/'
        );
        foreach ($dirs as $index => $dir) {
            $this->assertSame($dir, $CFG->dirroot . '/' . $correct[$index]);
        }
        // Test core.
        $dirs = mustache_template_finder::get_template_directories_for_component('core', 'clean');

        $correct = array(
            'theme/clean/templates/core/',
            'theme/bootstrapbase/templates/core/',
            'lib/templates/'
        );
        foreach ($dirs as $index => $dir) {
            $this->assertSame($dir, $CFG->dirroot . '/' . $correct[$index]);
        }
        return;
    }

    /**
     * @expectedException coding_exception
     */
    public function test_invalid_get_template_directories_for_component() {
        // Test something invalid.
        $dirs = mustache_template_finder::get_template_directories_for_component('octopus', 'clean');
    }

    public function test_get_template_filepath() {
        global $CFG;

        $filename = mustache_template_finder::get_template_filepath('core/pix_icon', 'clean');
        $correct = $CFG->dirroot . '/lib/templates/pix_icon.mustache';
        $this->assertSame($correct, $filename);
    }

    /**
     * @expectedException moodle_exception
     */
    public function test_invalid_get_template_filepath() {
        // Test something invalid.
        $dirs = mustache_template_finder::get_template_filepath('core/octopus', 'clean');
    }
}