Differences Between: [Versions 311 and 403] [Versions 400 and 403] [Versions 401 and 403] [Versions 402 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 namespace mod_scorm\backup; 18 19 defined('MOODLE_INTERNAL') || die(); 20 21 global $CFG; 22 require_once($CFG->libdir . "/phpunit/classes/restore_date_testcase.php"); 23 24 /** 25 * Restore date tests. 26 * 27 * @package mod_scorm 28 * @copyright 2017 onwards Ankit Agarwal <ankit.agrr@gmail.com> 29 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 30 */ 31 class restore_date_test extends \restore_date_testcase { 32 33 public function test_restore_dates() { 34 global $DB, $USER; 35 36 $time = 10000; 37 38 list($course, $scorm) = $this->create_course_and_module('scorm', ['timeopen' => $time, 'timeclose' => $time]); 39 $scoes = scorm_get_scoes($scorm->id); 40 $sco = array_shift($scoes); 41 scorm_insert_track($USER->id, $scorm->id, $sco->id, 4, 'cmi.core.score.raw', 10); 42 43 // We do not want second differences to fail our test because of execution delays. 44 $DB->set_field('scorm_scoes_value', 'timemodified', $time); 45 46 // Do backup and restore. 47 $newcourseid = $this->backup_and_restore($course); 48 $newscorm = $DB->get_record('scorm', ['course' => $newcourseid]); 49 50 $this->assertFieldsNotRolledForward($scorm, $newscorm, ['timemodified']); 51 $props = ['timeopen', 'timeclose']; 52 $this->assertFieldsRolledForward($scorm, $newscorm, $props); 53 54 $sql = "SELECT * 55 FROM {scorm_scoes_value} v 56 JOIN {scorm_attempt} a ON a.id = v.attemptid 57 WHERE a.scormid = ?"; 58 $tracks = $DB->get_records_sql($sql, [$newscorm->id]); 59 foreach ($tracks as $track) { 60 $this->assertEquals($time, $track->timemodified); 61 } 62 } 63 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body