Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.0.x will end 8 May 2023 (12 months).
  • Bug fixes for security issues in 4.0.x will end 13 November 2023 (18 months).
  • PHP version: minimum PHP 7.3.0 Note: the minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is also supported.
<?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/>.

/**
 * Unit test for the site generator
 *
 * @package tool_generator
 * @copyright 2013 David Monllaó
 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

< defined('MOODLE_INTERNAL') || die();
> namespace tool_generator;
< /** < * Silly class to access site_backend internal methods. < * < * @package tool_generator < * @copyright 2013 David Monllaó < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */ < class testable_tool_generator_site_backend extends tool_generator_site_backend {
> use tool_generator_site_backend;
< /** < * Public accessor. < * < * @return int < */ < public static function get_last_testcourse_id() { < return parent::get_last_testcourse_id(); < } < }
> defined('MOODLE_INTERNAL') || die();
/** * Unit test for the site generator * * @package tool_generator * @copyright 2013 David Monllaó * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class tool_generator_maketestsite_testcase extends advanced_testcase {
> class maketestsite_test extends \advanced_testcase {
/** * Checks that site courses shortnames are properly generated. */ public function test_shortnames_generation() { $this->resetAfterTest(); $this->setAdminUser(); $generator = $this->getDataGenerator(); // Shortname common prefix. $prefix = tool_generator_site_backend::SHORTNAMEPREFIX; $record = array(); // Without courses will be 0. $lastshortname = testable_tool_generator_site_backend::get_last_testcourse_id(); $this->assertEquals(0, $lastshortname); // Without {$prefix} + {no integer} courses will be 0. $record['shortname'] = $prefix . 'AA'; $generator->create_course($record); $record['shortname'] = $prefix . '__'; $generator->create_course($record); $record['shortname'] = $prefix . '12.2'; $generator->create_course($record); $lastshortname = testable_tool_generator_site_backend::get_last_testcourse_id(); $this->assertEquals(0, $lastshortname); // With {$prefix} + {integer} courses will be the higher one. $record['shortname'] = $prefix . '2'; $generator->create_course($record); $record['shortname'] = $prefix . '20'; $generator->create_course($record); $record['shortname'] = $prefix . '8'; $generator->create_course($record); $lastshortname = testable_tool_generator_site_backend::get_last_testcourse_id(); $this->assertEquals(20, $lastshortname); // Numeric order. for ($i = 9; $i < 14; $i++) { $record['shortname'] = $prefix . $i; $generator->create_course($record); } $lastshortname = testable_tool_generator_site_backend::get_last_testcourse_id(); $this->assertEquals(20, $lastshortname); }
> } > } > /** > * Silly class to access site_backend internal methods. > * > * @copyright 2013 David Monllaó > * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later > */ > class testable_tool_generator_site_backend extends tool_generator_site_backend {
> /** > * Public accessor. > * > * @return int > */ > public static function get_last_testcourse_id() { > return parent::get_last_testcourse_id(); > }