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 - https://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 mod_workshop\task;

use workshop;

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

global $CFG;

require_once($CFG->dirroot.'/mod/workshop/lib.php');

/**
 * Test the functionality provided by  the {@link mod_workshop\task\cron_task} scheduled task.
 *
 * @package     mod_workshop
 * @category    test
 * @copyright 2019 David Mudrák <david@moodle.com>
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class cron_task_test extends \advanced_testcase {

    /**
     * Test that the phase is automatically switched after the submissions deadline.
     */
    public function test_phase_switching() {
        global $DB;

        $this->resetAfterTest();
        $this->setAdminUser();

        // Set up a test workshop with 'Switch to the next phase after the submissions deadline' enabled.
        $generator = $this->getDataGenerator();
        $course = $generator->create_course();
        $workshop = $generator->create_module('workshop', [
            'course' => $course,
            'name' => 'Test Workshop',
        ]);

        $DB->update_record('workshop', [
            'id' => $workshop->id,
            'phase' => workshop::PHASE_SUBMISSION,
            'phaseswitchassessment' => 1,
            'submissionend' => time() - 1,
        ]);

        // Execute the cron.
        ob_start();
< cron_setup_user();
> \core\cron::setup_user();
$cron = new \mod_workshop\task\cron_task(); $cron->execute(); $output = ob_get_contents(); ob_end_clean(); // Assert that the phase has been switched. $this->assertStringContainsString('Processing automatic assessment phase switch', $output); $this->assertEquals(workshop::PHASE_ASSESSMENT, $DB->get_field('workshop', 'phase', ['id' => $workshop->id])); } public function test_that_phase_automatically_switched_event_is_triggerd_when_phase_switchassesment_is_active(): void { global $DB; $this->resetAfterTest(); $this->setAdminUser(); // Set up a test workshop with 'Switch to the next phase after the submissions deadline' enabled. $generator = $this->getDataGenerator(); $course = $generator->create_course(); $workshop = $generator->create_module('workshop', [ 'course' => $course, 'name' => 'Test Workshop', ]); $DB->update_record('workshop', [ 'id' => $workshop->id, 'phase' => workshop::PHASE_SUBMISSION, 'phaseswitchassessment' => 1, 'submissionend' => time() - 1, ]); // Execute the cron. $eventsink = $this->redirectEvents(); ob_start();
< cron_setup_user();
> \core\cron::setup_user();
$cron = new \mod_workshop\task\cron_task(); $cron->execute(); ob_end_clean(); $events = array_filter($eventsink->get_events(), function ($event) { return $event instanceof \mod_workshop\event\phase_automatically_switched; }); $this->assertCount(1, $events); $phaseswitchedevent = array_pop($events); $this->assertArrayHasKey('previousworkshopphase', $phaseswitchedevent->other); $this->assertArrayHasKey('targetworkshopphase', $phaseswitchedevent->other); $this->assertEquals($phaseswitchedevent->other['previousworkshopphase'], \workshop::PHASE_SUBMISSION); $this->assertEquals($phaseswitchedevent->other['targetworkshopphase'], \workshop::PHASE_ASSESSMENT); } }