forked from moodle/moodle
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
MDL-9367 restore: Roll only configuration dates
It was decided to roll only configuration dates and any date related to user content such as 'timecreated' , 'timemodified' etc should not be rolled forward.
- Loading branch information
1 parent
d509f80
commit 0d14fcb
Showing
57 changed files
with
1,617 additions
and
74 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,163 @@ | ||
<?php | ||
// This file is part of Moodle - http://moodle.org/ | ||
// | ||
// Moodle is free software: you can redistribute it and/or modify | ||
// it under the terms of the GNU General Public License as published by | ||
// the Free Software Foundation, either version 3 of the License, or | ||
// (at your option) any later version. | ||
// | ||
// Moodle is distributed in the hope that it will be useful, | ||
// but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
// GNU General Public License for more details. | ||
// | ||
// You should have received a copy of the GNU General Public License | ||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. | ||
|
||
/** | ||
* Restore dates test case. | ||
* | ||
* @package core | ||
* @category test | ||
* @copyright 2017 onwards Ankit Agarwal | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
|
||
defined('MOODLE_INTERNAL') || die(); | ||
|
||
require_once($CFG->dirroot . '/backup/util/includes/restore_includes.php'); | ||
require_once($CFG->dirroot . '/backup/util/includes/backup_includes.php'); | ||
|
||
|
||
/** | ||
* Advanced PHPUnit test case customised for testing restore dates in Moodle. | ||
* | ||
* @package core | ||
* @category test | ||
* @copyright 2017 onwards Ankit Agarwal | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
abstract class restore_date_testcase extends advanced_testcase { | ||
/** | ||
* @var int Course start date. | ||
*/ | ||
protected $startdate; | ||
|
||
/** | ||
* @var int Course restore date. | ||
*/ | ||
protected $restorestartdate; | ||
|
||
/** | ||
* Setup. | ||
*/ | ||
public function setUp() { | ||
global $CFG; | ||
|
||
parent::setUp(); | ||
$this->resetAfterTest(); | ||
$this->setAdminUser(); | ||
$this->startdate = strtotime('1 Jan 2017 00:00 GMT'); | ||
$this->restorestartdate = strtotime('1 Feb 2017 00:00 GMT'); | ||
$CFG->enableavailability = true; | ||
} | ||
|
||
/** | ||
* Backs a course up and restores it. | ||
* | ||
* @param stdClass $course Course object to backup | ||
* @param int $newdate If non-zero, specifies custom date for new course | ||
* @return int ID of newly restored course | ||
*/ | ||
protected function backup_and_restore($course, $newdate = 0) { | ||
global $USER, $CFG; | ||
|
||
// Turn off file logging, otherwise it can't delete the file (Windows). | ||
$CFG->backup_file_logger_level = backup::LOG_NONE; | ||
|
||
// Do backup with default settings. | ||
set_config('backup_general_users', 1, 'backup'); | ||
$bc = new backup_controller(backup::TYPE_1COURSE, $course->id, | ||
backup::FORMAT_MOODLE, backup::INTERACTIVE_NO, backup::MODE_GENERAL, | ||
$USER->id); | ||
$bc->execute_plan(); | ||
$results = $bc->get_results(); | ||
$file = $results['backup_destination']; | ||
$fp = get_file_packer('application/vnd.moodle.backup'); | ||
$filepath = $CFG->dataroot . '/temp/backup/test-restore-course'; | ||
$file->extract_to_pathname($fp, $filepath); | ||
$bc->destroy(); | ||
|
||
// Do restore to new course with default settings. | ||
$newcourseid = restore_dbops::create_new_course( | ||
$course->fullname, $course->shortname . '_2', $course->category); | ||
$rc = new restore_controller('test-restore-course', $newcourseid, | ||
backup::INTERACTIVE_NO, backup::MODE_GENERAL, $USER->id, | ||
backup::TARGET_NEW_COURSE); | ||
|
||
if (empty($newdate)) { | ||
$newdate = $this->restorestartdate; | ||
} | ||
|
||
$rc->get_plan()->get_setting('course_startdate')->set_value($newdate); | ||
$this->assertTrue($rc->execute_precheck()); | ||
$rc->execute_plan(); | ||
$rc->destroy(); | ||
|
||
return $newcourseid; | ||
} | ||
|
||
/** | ||
* Helper method to create a course and a module. | ||
* | ||
* @param string $modulename | ||
* @param array|stdClass $record | ||
* @return array | ||
*/ | ||
protected function create_course_and_module($modulename, $record = []) { | ||
// Create a course with specific start date. | ||
$record = (array)$record; | ||
$generator = $this->getDataGenerator(); | ||
$course = $generator->create_course(['startdate' => $this->startdate]); | ||
$record = array_merge(['course' => $course->id], $record); | ||
$module = $this->getDataGenerator()->create_module($modulename, $record); | ||
return [$course, $module]; | ||
} | ||
|
||
/** | ||
* Verify that the given properties are not rolled. | ||
* | ||
* @param stdClass $oldinstance | ||
* @param stdClass $newinstance | ||
* @param [] $props | ||
*/ | ||
protected function assertFieldsNotRolledForward($oldinstance, $newinstance, $props) { | ||
foreach ($props as $prop) { | ||
$this->assertEquals($oldinstance->$prop, $newinstance->$prop, "'$prop' should not roll forward."); | ||
} | ||
} | ||
|
||
/** | ||
* Verify that the given properties are rolled. | ||
* | ||
* @param stdClass $oldinstance | ||
* @param stdClass $newinstance | ||
* @param [] $props | ||
*/ | ||
protected function assertFieldsRolledForward($oldinstance, $newinstance, $props) { | ||
$diff = $this->get_diff(); | ||
foreach ($props as $prop) { | ||
$this->assertEquals(($oldinstance->$prop + $diff), $newinstance->$prop, "'$prop' doesn't roll as expected."); | ||
} | ||
} | ||
|
||
/** | ||
* Get time diff between start date and restore date in seconds. | ||
* | ||
* @return mixed | ||
*/ | ||
protected function get_diff() { | ||
return ($this->restorestartdate - $this->startdate); | ||
} | ||
|
||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,92 @@ | ||
<?php | ||
// This file is part of Moodle - http://moodle.org/ | ||
// | ||
// Moodle is free software: you can redistribute it and/or modify | ||
// it under the terms of the GNU General Public License as published by | ||
// the Free Software Foundation, either version 3 of the License, or | ||
// (at your option) any later version. | ||
// | ||
// Moodle is distributed in the hope that it will be useful, | ||
// but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
// GNU General Public License for more details. | ||
// | ||
// You should have received a copy of the GNU General Public License | ||
// along with Moodle. If not, see <http://www.gnu.org/licenses/>. | ||
|
||
/** | ||
* Restore date tests. | ||
* | ||
* @package mod_assign | ||
* @copyright 2017 onwards Ankit Agarwal <ankit.agrr@gmail.com> | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
|
||
defined('MOODLE_INTERNAL') || die(); | ||
|
||
global $CFG; | ||
require_once($CFG->libdir . "/phpunit/classes/restore_date_testcase.php"); | ||
require_once($CFG->dirroot . '/mod/assign/tests/base_test.php'); | ||
|
||
/** | ||
* Restore date tests. | ||
* | ||
* @package mod_assign | ||
* @copyright 2017 onwards Ankit Agarwal <ankit.agrr@gmail.com> | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
class mod_assign_restore_date_testcase extends restore_date_testcase { | ||
|
||
/** | ||
* Test restore dates. | ||
*/ | ||
public function test_restore_dates() { | ||
global $DB, $USER; | ||
|
||
$record = ['cutoffdate' => 100, 'allowsubmissionsfromdate' => 100, 'duedate' => 100, 'timemodified' => 100]; | ||
list($course, $assign) = $this->create_course_and_module('assign', $record); | ||
$cm = $DB->get_record('course_modules', ['course' => $course->id, 'instance' => $assign->id]); | ||
$assignobj = new testable_assign(context_module::instance($cm->id), $cm, $course); | ||
$submission = $assignobj->get_user_submission($USER->id, true); | ||
$grade = $assignobj->get_user_grade($USER->id, true); | ||
|
||
// User override. | ||
$override = (object)[ | ||
'assignid' => $assign->id, | ||
'groupid' => 0, | ||
'userid' => $USER->id, | ||
'sortorder' => 1, | ||
'allowsubmissionsfromdate' => 100, | ||
'duedate' => 200, | ||
'cutoffdate' => 300 | ||
]; | ||
$DB->insert_record('assign_overrides', $override); | ||
|
||
// Do backup and restore. | ||
$newcourseid = $this->backup_and_restore($course); | ||
$newassign = $DB->get_record('assign', ['course' => $newcourseid]); | ||
|
||
$this->assertFieldsNotRolledForward($assign, $newassign, ['timemodified']); | ||
$props = ['allowsubmissionsfromdate', 'duedate', 'cutoffdate']; | ||
$this->assertFieldsRolledForward($assign, $newassign, $props); | ||
|
||
$newsubmission = $DB->get_record('assign_submission', ['assignment' => $newassign->id]); | ||
$newoverride = $DB->get_record('assign_overrides', ['assignid' => $newassign->id]); | ||
$newgrade = $DB->get_record('assign_grades', ['assignment' => $newassign->id]); | ||
|
||
// Assign submission time checks. | ||
$this->assertEquals($submission->timecreated, $newsubmission->timecreated); | ||
$this->assertEquals($submission->timemodified, $newsubmission->timemodified); | ||
|
||
// Assign override time checks. | ||
$diff = $this->get_diff(); | ||
$this->assertEquals($override->duedate + $diff, $newoverride->duedate); | ||
$this->assertEquals($override->cutoffdate + $diff, $newoverride->cutoffdate); | ||
$this->assertEquals($override->allowsubmissionsfromdate + $diff, $newoverride->allowsubmissionsfromdate); | ||
|
||
// Assign grade time checks. | ||
$this->assertEquals($grade->timecreated, $newgrade->timecreated); | ||
$this->assertEquals($grade->timemodified, $newgrade->timemodified); | ||
|
||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.