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.

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  }