Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 4.1.x will end 13 November 2023 (12 months).
  • Bug fixes for security issues in 4.1.x will end 10 November 2025 (36 months).
  • PHP version: minimum PHP 7.4.0 Note: minimum PHP version has increased since Moodle 4.0. PHP 8.0.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/>.

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 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);
        $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); $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); $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; // 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); $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); $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()); } } } } }