Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.3.x will end 7 October 2024 (12 months).
  • Bug fixes for security issues in 4.3.x will end 21 April 2025 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.2.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  namespace mod_data\backup;
  18  
  19  defined('MOODLE_INTERNAL') || die();
  20  
  21  global $CFG;
  22  require_once($CFG->libdir . "/phpunit/classes/restore_date_testcase.php");
  23  require_once($CFG->dirroot . '/rating/lib.php');
  24  
  25  /**
  26   * Restore date tests.
  27   *
  28   * @package    mod_data
  29   * @copyright  2017 onwards Ankit Agarwal <ankit.agrr@gmail.com>
  30   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  31   */
  32  class restore_date_test extends \restore_date_testcase {
  33  
  34      /**
  35       * Test restore dates.
  36       */
  37      public function test_restore_dates() {
  38          global $DB, $USER;
  39  
  40          $gg = $this->getDataGenerator()->get_plugin_generator('mod_data');
  41          $record = ['assesstimefinish' => 100, 'assesstimestart' => 100, 'ratingtime' => 1, 'assessed' => 2, 'scale' => 1,
  42                     'timeavailablefrom' => 100, 'timeavailableto' => 100, 'timeviewfrom' => 100, 'timeviewto' => 100];
  43          list($course, $data) = $this->create_course_and_module('data', $record);
  44  
  45          // Data field/record.
  46          $timestamp = 996699;
  47          $diff = $this->get_diff();
  48          $record = new \stdClass();
  49          $record->name = 'field-1';
  50          $record->type = 'text';
  51          $field = $gg->create_field($record, $data);
  52          $datarecordid = $gg->create_entry($data, [$field->field->id => 'NERDS NERDS EVERYWHERE, NO BRAIN TO THINK']);
  53          $datarecord = $DB->get_record('data_records', ['id' => $datarecordid]);
  54  
  55          // Ratings.
  56          $ratingoptions = new \stdClass;
  57          $ratingoptions->context = \context_module::instance($data->cmid);
  58          $ratingoptions->ratingarea = 'entry';
  59          $ratingoptions->component = 'mod_data';
  60          $ratingoptions->itemid  = $datarecord->id;
  61          $ratingoptions->scaleid = 2;
  62          $ratingoptions->userid  = $USER->id;
  63          $rating = new \rating($ratingoptions);
  64          $rating->update_rating(2);
  65          $rating = $DB->get_record('rating', ['itemid' => $datarecord->id]);
  66  
  67          // Do backup and restore.
  68          $newcourseid = $this->backup_and_restore($course);
  69          $newdata = $DB->get_record('data', ['course' => $newcourseid]);
  70  
  71          $this->assertFieldsNotRolledForward($data, $newdata, ['timemodified']);
  72          $props = ['assesstimefinish', 'assesstimestart', 'timeavailablefrom', 'timeavailableto', 'timeviewfrom', 'timeviewto'];
  73          $this->assertFieldsRolledForward($data, $newdata, $props);
  74  
  75          $newdatarecord = $DB->get_record('data_records', ['dataid' => $newdata->id]);
  76          $newcm = $DB->get_record('course_modules', ['course' => $newcourseid, 'instance' => $newdata->id]);
  77  
  78          // Data record time checks.
  79          $this->assertEquals($datarecord->timecreated, $newdatarecord->timecreated);
  80          $this->assertEquals($datarecord->timemodified, $newdatarecord->timemodified);
  81  
  82          // Rating test.
  83          $newrating = $DB->get_record('rating', ['contextid' => \context_module::instance($newcm->id)->id]);
  84          $this->assertEquals($rating->timecreated, $newrating->timecreated);
  85          $this->assertEquals($rating->timemodified, $newrating->timemodified);
  86      }
  87  }