Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 3.11.x will end 14 Nov 2022 (12 months plus 6 months extension).
  • Bug fixes for security issues in 3.11.x will end 13 Nov 2023 (18 months plus 12 months extension).
  • PHP version: minimum PHP 7.3.0 Note: minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is 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/>.

/**
 * Behat data generator for core_question.
 *
 * @package   core_question
 * @category  test
 * @copyright 2020 The Open University
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

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


/**
 * Behat data generator for core_question.
 */
class behat_core_question_generator extends behat_generator_base {

    protected function get_creatable_entities(): array {
        // Note, for historical reasons, questions and question categories
        // are generated by behat_core_generator.
        return [
            'Tags' => [
                'singular' => 'Tag',
                'datagenerator' => 'question_tag',
                'required' => ['question', 'tag'],
                'switchids' => ['question' => 'questionid'],
            ],
> 'updated questions' => [ ]; > 'singular' => 'question', } > 'datagenerator' => 'updated_question', > 'required' => ['question', 'questioncategory'], /** > 'switchids' => ['question' => 'id', 'questioncategory' => 'category'], * Look up the id of a question from its name. > ],
* * @param string $questionname the question name, for example 'Question 1'. * @return int corresponding id. */ protected function get_question_id(string $questionname): int { global $DB; if (!$id = $DB->get_field('question', 'id', ['name' => $questionname])) { throw new Exception('There is no question with name "' . $questionname . '".'); } return $id;
> } } > } > /** > * Update a question > * > * This will update a question matching the supplied name with the provided data, creating a new version in the process. > * > * @param array $data the row of data from the behat script. > * @return void > */ > protected function process_updated_question(array $data): void { > global $DB; > $question = $DB->get_record('question', ['id' => $data['id']], '*', MUST_EXIST); > foreach ($data as $key => $value) { > $question->{$key} = $value; > } > > $this->datagenerator->get_plugin_generator('core_question')->update_question($question);