Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.10.x will end 8 November 2021 (12 months).
  • Bug fixes for security issues in 3.10.x will end 9 May 2022 (18 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.
<?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/>.

/**
 * Backup webservice tests.
 *
 * @package    core_backup
 * @copyright  2020 onward The Moodle Users Association <https://moodleassociation.org/>
 * @author     Matt Porritt <mattp@catalyst-au.net>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

defined('MOODLE_INTERNAL') || die();

global $CFG;
require_once($CFG->dirroot . '/backup/util/includes/backup_includes.php');
require_once($CFG->dirroot . '/backup/util/includes/restore_includes.php');
require_once($CFG->dirroot . '/webservice/tests/helpers.php');
require_once($CFG->dirroot . '/backup/externallib.php');

/**
 * Backup webservice tests.
 *
 * @package    core_backup
 * @copyright  2020 onward The Moodle Users Association <https://moodleassociation.org/>
 * @author     Matt Porritt <mattp@catalyst-au.net>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class backup_external_testcase extends externallib_advanced_testcase {

    /**
     * Set up tasks for all tests.
     */
< protected function setUp() {
> protected function setUp(): void {
global $CFG; $this->resetAfterTest(true); // Disable all loggers. $CFG->backup_error_log_logger_level = backup::LOG_NONE; $CFG->backup_output_indented_logger_level = backup::LOG_NONE; $CFG->backup_file_logger_level = backup::LOG_NONE; $CFG->backup_database_logger_level = backup::LOG_NONE; $CFG->backup_file_logger_level_extra = backup::LOG_NONE; } /** * Test getting course copy progress. */ public function test_get_copy_progress() { global $USER; $this->setAdminUser(); // Create a course with some availability data set. $generator = $this->getDataGenerator(); $course = $generator->create_course(); $courseid = $course->id; // Mock up the form data for use in tests. $formdata = new \stdClass; $formdata->courseid = $courseid; $formdata->fullname = 'foo'; $formdata->shortname = 'bar'; $formdata->category = 1; $formdata->visible = 1; $formdata->startdate = 1582376400; $formdata->enddate = 0; $formdata->idnumber = 123; $formdata->userdata = 1; $formdata->role_1 = 1; $formdata->role_3 = 3; $formdata->role_5 = 5; $coursecopy = new \core_backup\copy\copy($formdata); $copydetails = $coursecopy->create_copy(); $copydetails['operation'] = \backup::OPERATION_BACKUP; $params = array('copies' => $copydetails); $returnvalue = core_backup_external::get_copy_progress($params); // We need to execute the return values cleaning process to simulate the web service server. $returnvalue = external_api::clean_returnvalue(core_backup_external::get_copy_progress_returns(), $returnvalue); $this->assertEquals(\backup::STATUS_AWAITING, $returnvalue[0]['status']); $this->assertEquals(0, $returnvalue[0]['progress']); $this->assertEquals($copydetails['backupid'], $returnvalue[0]['backupid']); $this->assertEquals(\backup::OPERATION_BACKUP, $returnvalue[0]['operation']); // We are expecting trace output during this test. $this->expectOutputRegex("/$courseid/"); // Execute adhoc task and create the copy. $now = time(); $task = \core\task\manager::get_next_adhoc_task($now); $this->assertInstanceOf('\\core\\task\\asynchronous_copy_task', $task); $task->execute(); \core\task\manager::adhoc_task_complete($task); // Check the copy progress now. $params = array('copies' => $copydetails); $returnvalue = core_backup_external::get_copy_progress($params); $returnvalue = external_api::clean_returnvalue(core_backup_external::get_copy_progress_returns(), $returnvalue); $this->assertEquals(\backup::STATUS_FINISHED_OK, $returnvalue[0]['status']); $this->assertEquals(1, $returnvalue[0]['progress']); $this->assertEquals($copydetails['restoreid'], $returnvalue[0]['backupid']); $this->assertEquals(\backup::OPERATION_RESTORE, $returnvalue[0]['operation']); } /** * Test ajax submission of course copy process. */ public function test_submit_copy_form() { global $DB; $this->setAdminUser(); // Create a course with some availability data set. $generator = $this->getDataGenerator(); $course = $generator->create_course(); $courseid = $course->id; // Moodle form requires this for validation. $sesskey = sesskey(); $_POST['sesskey'] = $sesskey; // Mock up the form data for use in tests. $formdata = new \stdClass; $formdata->courseid = $courseid; $formdata->returnto = ''; $formdata->returnurl = ''; $formdata->sesskey = $sesskey; $formdata->_qf__core_backup_output_copy_form = 1; $formdata->fullname = 'foo'; $formdata->shortname = 'bar'; $formdata->category = 1; $formdata->visible = 1; $formdata->startdate = array('day' => 5, 'month' => 5, 'year' => 2020, 'hour' => 0, 'minute' => 0); $formdata->idnumber = 123; $formdata->userdata = 1; $formdata->role_1 = 1; $formdata->role_3 = 3; $formdata->role_5 = 5; $urlform = http_build_query($formdata, '', '&'); // Take the form data and url encode it. $jsonformdata = json_encode($urlform); // Take form string and JSON encode. $returnvalue = core_backup_external::submit_copy_form($jsonformdata); $returnjson = external_api::clean_returnvalue(core_backup_external::submit_copy_form_returns(), $returnvalue); $copyids = json_decode($returnjson, true); $backuprec = $DB->get_record('backup_controllers', array('backupid' => $copyids['backupid'])); $restorerec = $DB->get_record('backup_controllers', array('backupid' => $copyids['restoreid'])); // Check backup was completed successfully. $this->assertEquals(backup::STATUS_AWAITING, $backuprec->status); $this->assertEquals(0, $backuprec->progress); $this->assertEquals('backup', $backuprec->operation); // Check restore was completed successfully. $this->assertEquals(backup::STATUS_REQUIRE_CONV, $restorerec->status); $this->assertEquals(0, $restorerec->progress); $this->assertEquals('restore', $restorerec->operation); } }