Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.3.x will end 7 October 2024 (12 months).
  • Bug fixes for security issues in 4.3.x will end 21 April 2025 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.2.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/>.

< defined('MOODLE_INTERNAL') || die();
> namespace tool_generator; > > use tool_generator_course_backend;
/** * Automated unit testing. This tests the 'make large course' backend, * using the 'XS' option so that it completes quickly. * * @package tool_generator * @copyright 2013 The Open University * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class tool_generator_maketestcourse_testcase extends advanced_testcase {
> class maketestcourse_test extends \advanced_testcase {
/** * Creates a small test course and checks all the components have been put in place. */ public function test_make_xs_course() { global $DB; $this->resetAfterTest(); $this->setAdminUser(); $expectedshortname = 'TOOL_MAKELARGECOURSE_XS'; $expectedfullname = 'Ridiculous fullname'; $expectedsummary = 'who even knows what this is about'; // Create the XS course. $backend = new tool_generator_course_backend( $expectedshortname, 0, false, false, false, $expectedfullname, $expectedsummary ); $courseid = $backend->make(); // Get course details. $course = get_course($courseid);
< $context = context_course::instance($courseid);
> $context = \context_course::instance($courseid);
$modinfo = get_fast_modinfo($course); // Check course names. $this->assertEquals($expectedshortname, $course->shortname); $this->assertEquals($expectedfullname, $course->fullname); // Check course summary. $this->assertEquals($expectedsummary, $course->summary); // Check sections (just section 0 plus one other). $this->assertEquals(2, count($modinfo->get_section_info_all())); // Check user is enrolled.
> // enroladminnewcourse is enabled by default, so admin is also enrolled as teacher.
$users = get_enrolled_users($context);
< $this->assertEquals(1, count($users)); < $this->assertEquals('tool_generator_000001', reset($users)->username);
> $this->assertEquals(2, count($users)); > $usernames = array_map(function($user) { > return $user->username; > }, $users); > $this->assertTrue(in_array('admin', $usernames)); > $this->assertTrue(in_array('tool_generator_000001', $usernames));
// Check there's a page on the course. $pages = $modinfo->get_instances_of('page'); $this->assertEquals(1, count($pages)); // Check there are small files. $resources = $modinfo->get_instances_of('resource'); $ok = false; foreach ($resources as $resource) { if ($resource->sectionnum == 0) { // The one in section 0 is the 'small files' resource. $ok = true; break; } } $this->assertTrue($ok); // Check it contains 2 files (the default txt and a dat file). $fs = get_file_storage();
< $resourcecontext = context_module::instance($resource->id);
> $resourcecontext = \context_module::instance($resource->id);
$files = $fs->get_area_files($resourcecontext->id, 'mod_resource', 'content', false, 'filename', false); $files = array_values($files); $this->assertEquals(2, count($files)); $this->assertEquals('resource1.txt', $files[0]->get_filename()); $this->assertEquals('smallfile0.dat', $files[1]->get_filename()); // Check there's a single 'big' file (it's actually only 8KB). $ok = false; foreach ($resources as $resource) { if ($resource->sectionnum == 1) { $ok = true; break; } } $this->assertTrue($ok); // Check it contains 2 files.
< $resourcecontext = context_module::instance($resource->id);
> $resourcecontext = \context_module::instance($resource->id);
$files = $fs->get_area_files($resourcecontext->id, 'mod_resource', 'content', false, 'filename', false); $files = array_values($files); $this->assertEquals(2, count($files)); $this->assertEquals('bigfile0.dat', $files[0]->get_filename()); $this->assertEquals('resource2.txt', $files[1]->get_filename()); // Get forum and count the number of posts on it. $forums = $modinfo->get_instances_of('forum'); $forum = reset($forums); $posts = $DB->count_records_sql(" SELECT COUNT(1) FROM {forum_posts} fp JOIN {forum_discussions} fd ON fd.id = fp.discussion WHERE fd.forum = ?", array($forum->instance)); $this->assertEquals(2, $posts); } /** * Creates an small test course with fixed data set and checks the used sections and users. */ public function test_fixed_data_set() { $this->resetAfterTest(); $this->setAdminUser(); // Create the S course (more sections and activities than XS). $backend = new tool_generator_course_backend('TOOL_S_COURSE_1', 1, true, false, false); $courseid = $backend->make(); // Get course details. $course = get_course($courseid); $modinfo = get_fast_modinfo($course); // Check module instances belongs to section 1. $instances = $modinfo->get_instances_of('page'); foreach ($instances as $instance) { $this->assertEquals(1, $instance->sectionnum); } // Users that started discussions are the same. $forums = $modinfo->get_instances_of('forum'); $discussions = forum_get_discussions(reset($forums), 'd.timemodified ASC'); $lastusernumber = 0; $discussionstarters = array(); foreach ($discussions as $discussion) {
< $usernumber = core_user::get_user($discussion->userid, 'id, idnumber')->idnumber;
> $usernumber = \core_user::get_user($discussion->userid, 'id, idnumber')->idnumber;
// Checks that the users are odd numbers. $this->assertEquals(1, $usernumber % 2); // Checks that the users follows an increasing order. $this->assertGreaterThan($lastusernumber, $usernumber); $lastusernumber = $usernumber; $discussionstarters[$discussion->userid] = $discussion->subject; } } /** * Creates a small test course specifying a maximum size and checks the generated files size is limited. */ public function test_filesize_limit() { $this->resetAfterTest(); $this->setAdminUser(); // Limit. $filesizelimit = 100; // Create a limited XS course. $backend = new tool_generator_course_backend('TOOL_XS_LIMITED', 0, false, $filesizelimit, false); $courseid = $backend->make(); $course = get_course($courseid); $modinfo = get_fast_modinfo($course); // Check there are small files. $fs = get_file_storage(); $resources = $modinfo->get_instances_of('resource'); foreach ($resources as $resource) {
< $resourcecontext = context_module::instance($resource->id);
> $resourcecontext = \context_module::instance($resource->id);
$files = $fs->get_area_files($resourcecontext->id, 'mod_resource', 'content', false, 'filename', false); foreach ($files as $file) { if ($file->get_mimetype() == 'application/octet-stream') { $this->assertLessThanOrEqual($filesizelimit, $file->get_filesize()); } } } // Create a non-limited XS course. $backend = new tool_generator_course_backend('TOOL_XS_NOLIMITS', 0, false, false, false); $courseid = $backend->make(); $course = get_course($courseid); $modinfo = get_fast_modinfo($course); // Check there are small files. $fs = get_file_storage(); $resources = $modinfo->get_instances_of('resource'); foreach ($resources as $resource) {
< $resourcecontext = context_module::instance($resource->id);
> $resourcecontext = \context_module::instance($resource->id);
$files = $fs->get_area_files($resourcecontext->id, 'mod_resource', 'content', false, 'filename', false); foreach ($files as $file) { if ($file->get_mimetype() == 'application/octet-stream') { $this->assertGreaterThan($filesizelimit, (int)$file->get_filesize()); } } } } }