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] [Versions 39 and 311] [Versions 39 and 400] [Versions 39 and 401] [Versions 39 and 402] [Versions 39 and 403]

   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   * This file contains test helper code for testing the upgrade to the new
  19   * question engine. The actual tests are organised by question type in files
  20   * like question/type/truefalse/tests/upgradelibnewqe_test.php.
  21   *
  22   * @package    moodlecore
  23   * @subpackage questionengine
  24   * @copyright  2009 The Open University
  25   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  26   */
  27  
  28  
  29  defined('MOODLE_INTERNAL') || die();
  30  
  31  global $CFG;
  32  require_once (__DIR__ . '/../upgradelib.php');
  33  
  34  
  35  /**
  36   * Subclass of question_engine_attempt_upgrader to help with testing.
  37   *
  38   * @copyright  2009 The Open University
  39   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  40   */
  41  class test_question_engine_attempt_upgrader extends question_engine_attempt_upgrader {
  42      public function prevent_timeout() {
  43      }
  44  
  45      public function __construct($loader, $logger) {
  46          $this->questionloader = $loader;
  47          $this->logger = $logger;
  48      }
  49  }
  50  
  51  
  52  /**
  53   * Subclass of question_engine_upgrade_question_loader for unit testing.
  54   *
  55   * @copyright  2009 The Open University
  56   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  57   */
  58  class test_question_engine_upgrade_question_loader extends question_engine_upgrade_question_loader {
  59      public function put_question_in_cache($question) {
  60          $this->cache[$question->id] = $question;
  61      }
  62  
  63      public function load_question($questionid, $quizid) {
  64          global $CFG;
  65  
  66          if (isset($this->cache[$questionid])) {
  67              return $this->cache[$questionid];
  68          }
  69  
  70          return null;
  71      }
  72  
  73      public function put_dataset_in_cache($questionid, $selecteditem, $dataset) {
  74          $this->datasetcache[$questionid][$selecteditem] = $dataset;
  75      }
  76  
  77      public function load_dataset($questionid, $selecteditem) {
  78          global $DB;
  79  
  80          if (isset($this->datasetcache[$questionid][$selecteditem])) {
  81              return $this->datasetcache[$questionid][$selecteditem];
  82          }
  83  
  84          throw new coding_exception('Test dataset not loaded.');
  85      }
  86  }
  87  
  88  
  89  /**
  90   * Base class for tests that thest the upgrade of one particular attempt and
  91   * one question.
  92   *
  93   * @copyright  2009 The Open University
  94   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  95   */
  96  abstract class question_attempt_upgrader_test_base extends advanced_testcase {
  97      protected $updater;
  98      protected $loader;
  99  
 100      protected function setUp() {
 101          parent::setUp();
 102          $logger = new dummy_question_engine_assumption_logger();
 103          $this->loader = new test_question_engine_upgrade_question_loader($logger);
 104          $this->updater = new test_question_engine_attempt_upgrader($this->loader, $logger);
 105      }
 106  
 107      protected function tearDown() {
 108          $this->updater = null;
 109          parent::tearDown();
 110      }
 111  
 112      /**
 113       * Clear text, bringing independence of html2text results
 114       *
 115       * Some tests performing text comparisons of converted text are too much
 116       * dependent of the behavior of the html2text library. This function is
 117       * aimed to reduce such dependencies that should not affect the results
 118       * of these question attempt upgrade tests.
 119       */
 120      protected function clear_html2text_dependencies($qa) {
 121          // Cleaning all whitespace should be enough to ignore any html2text dependency
 122          if (property_exists($qa, 'responsesummary')) {
 123              $qa->responsesummary = preg_replace('/\s/', '', $qa->responsesummary);
 124          }
 125          if (property_exists($qa, 'questionsummary')) {
 126              $qa->questionsummary = preg_replace('/\s/', '', $qa->questionsummary);
 127          }
 128      }
 129  
 130      /**
 131       * Compare two qas, ignoring inessential differences.
 132       * @param object $expectedqa the expected qa.
 133       * @param object $qa the actual qa.
 134       */
 135      protected function compare_qas($expectedqa, $qa) {
 136          $this->clear_html2text_dependencies($expectedqa);
 137          $this->clear_html2text_dependencies($qa);
 138  
 139          $this->assertEquals($expectedqa, $qa);
 140      }
 141  }