Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.11.x will end 14 Nov 2022 (12 months plus 6 months extension).
  • Bug fixes for security issues in 3.11.x will end 13 Nov 2023 (18 months plus 12 months extension).
  • PHP version: minimum PHP 7.3.0 Note: minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is supported too.
   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   * tool_brickfield check test.
  19   *
  20   * @package    tool_brickfield
  21   * @copyright  2020 onward: Brickfield Education Labs, https://www.brickfield.ie
  22   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   */
  24  
  25  namespace tool_brickfield\local\htmlchecker\common\checks;
  26  
  27  defined('MOODLE_INTERNAL') || die();
  28  
  29  require_once ('all_checks.php');
  30  
  31  /**
  32   * Class headers_have_text_testcase
  33   */
  34  class headers_have_text_test extends all_checks {
  35      /** @var string Check type */
  36      protected $checktype = 'headers_have_text';
  37  
  38      /** @var string Html fail */
  39      private $htmlfail = <<<EOD
  40      <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
  41      <html>
  42          <head>
  43              <title>Header has text - Fail</title>
  44          </head>
  45          <body>
  46          <h1>This is a correct header</h1>
  47          <p>Intrinsicly actualize web-enabled users and cross functional growth strategies. Monotonectally simplify B2B opportunities
  48          vis-a-vis top-line processes.</p>
  49          <h2></h2>
  50          <p>Globally synergize ethical process improvements before go forward technology. Synergistically seize backward-compatible
  51          quality vectors through magnetic sources. Distinctively reintermediate virtual "outside the box" thinking without market
  52          positioning supply chains.</p>
  53          </body>
  54      </html>
  55  EOD;
  56  
  57      /** @var string Html pass */
  58      private $htmlpass = <<<EOD
  59      <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
  60      <html>
  61          <head>
  62              <title>Header has text - Fail</title>
  63          </head>
  64          <body>
  65          <h1>This is a correct header</h1>
  66          <p>Intrinsicly actualize web-enabled users and cross functional growth strategies. Monotonectally simplify B2B opportunities
  67           vis-a-vis top-line processes.</p>
  68          <h2>This header is also OK.</h2>
  69          <p>Globally synergize ethical process improvements before go forward technology. Synergistically seize backward-compatible
  70          quality vectors through magnetic sources. Distinctively reintermediate virtual "outside the box" thinking without market
  71          positioning supply chains.</p>
  72          </body>
  73      </html>
  74  EOD;
  75  
  76      /**
  77       * Test for headers not containing text
  78       */
  79      public function test_check() {
  80          $results = $this->get_checker_results($this->htmlfail);
  81          $this->assertTrue($results[0]->element->tagName == 'h2');
  82  
  83          $results = $this->get_checker_results($this->htmlpass);
  84          $this->assertEmpty($results);
  85      }
  86  }