mirror of
https://github.com/moodle/moodle.git
synced 2025-08-05 08:56:36 +02:00
MDL-64242 qtype_essay: more efficient query in restore code
Thanks to Juan Ibarra for the suggestion that lead to this fix.
This commit is contained in:
parent
694513e2fe
commit
822b4abb1e
2 changed files with 75 additions and 7 deletions
|
@ -95,15 +95,15 @@ class restore_qtype_essay_plugin extends restore_qtype_plugin {
|
||||||
global $DB;
|
global $DB;
|
||||||
|
|
||||||
$essayswithoutoptions = $DB->get_records_sql("
|
$essayswithoutoptions = $DB->get_records_sql("
|
||||||
SELECT *
|
SELECT q.*
|
||||||
FROM {question} q
|
FROM {question} q
|
||||||
|
JOIN {backup_ids_temp} bi ON bi.newitemid = q.id
|
||||||
|
LEFT JOIN {qtype_essay_options} qeo ON qeo.questionid = q.id
|
||||||
WHERE q.qtype = ?
|
WHERE q.qtype = ?
|
||||||
AND NOT EXISTS (
|
AND qeo.id IS NULL
|
||||||
SELECT 1
|
AND bi.backupid = ?
|
||||||
FROM {qtype_essay_options}
|
AND bi.itemname = ?
|
||||||
WHERE questionid = q.id
|
", array('essay', $this->get_restoreid(), 'question_created'));
|
||||||
)
|
|
||||||
", array('essay'));
|
|
||||||
|
|
||||||
foreach ($essayswithoutoptions as $q) {
|
foreach ($essayswithoutoptions as $q) {
|
||||||
$defaultoptions = new stdClass();
|
$defaultoptions = new stdClass();
|
||||||
|
|
68
question/type/essay/tests/restore_test.php
Normal file
68
question/type/essay/tests/restore_test.php
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
<?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/>.
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test restore logic.
|
||||||
|
*
|
||||||
|
* @package qtype_essay
|
||||||
|
* @copyright 2019 The Open University
|
||||||
|
* @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");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test restore logic.
|
||||||
|
*
|
||||||
|
* @copyright 2019 The Open University
|
||||||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||||
|
*/
|
||||||
|
class qtype_essay_restore_testcase extends restore_date_testcase {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test missing qtype_essay_options creation.
|
||||||
|
*
|
||||||
|
* Old backup files may contain essays with no qtype_essay_options record.
|
||||||
|
* During restore, we add default options for any questions like that.
|
||||||
|
* That is what is tested in this file.
|
||||||
|
*/
|
||||||
|
public function test_restore_create_missing_qtype_essay_options() {
|
||||||
|
global $DB;
|
||||||
|
|
||||||
|
// Create a course with one essay question in its question bank.
|
||||||
|
$generator = $this->getDataGenerator();
|
||||||
|
$course = $generator->create_course();
|
||||||
|
$contexts = new question_edit_contexts(context_course::instance($course->id));
|
||||||
|
$category = question_make_default_categories($contexts->all());
|
||||||
|
$questiongenerator = $this->getDataGenerator()->get_plugin_generator('core_question');
|
||||||
|
$essay = $questiongenerator->create_question('essay', null, array('category' => $category->id));
|
||||||
|
|
||||||
|
// Remove the options record, which means that the backup will look like a backup made in an old Moodle.
|
||||||
|
$DB->delete_records('qtype_essay_options', ['questionid' => $essay->id]);
|
||||||
|
|
||||||
|
// Do backup and restore.
|
||||||
|
$newcourseid = $this->backup_and_restore($course);
|
||||||
|
|
||||||
|
// Verify that the restored question has options.
|
||||||
|
$contexts = new question_edit_contexts(context_course::instance($newcourseid));
|
||||||
|
$newcategory = question_make_default_categories($contexts->all());
|
||||||
|
$newessay = $DB->get_record('question', ['category' => $newcategory->id, 'qtype' => 'essay']);
|
||||||
|
$this->assertTrue($DB->record_exists('qtype_essay_options', ['questionid' => $newessay->id]));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue