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/>.

/**
 * Tests for report_helper.
 *
 * @package    core
 * @category   test
 * @copyright  2021 Sujith Haridasan
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

namespace core;

use moodle_url;
use core\report_helper;

/**
 * Tests the functions for report_helper class.
 */
class report_helper_test extends \advanced_testcase {
    /**
     * Data provider for testing selected report for same and different courses
     *
     * @return array
     */
    public function data_selected_report():array {
        return [
            ['course_url_id' => [
                ['url' => '/test', 'id' => 1],
                ['url' => '/foo', 'id' => 1]]
            ],
            ['course_url_id' => [
                ['url' => '/test', 'id' => 1],
                ['url' => '/foo/bar', 'id' => 2]]
            ]
        ];
    }

    /**
     * Testing selected report saved in $USER session.
     *
     * @dataProvider data_selected_report
     * @param array $courseurlid The array has both course url and course id
     */
    public function test_save_selected_report(array $courseurlid):void {
        global $USER;

        $url1 = new moodle_url($courseurlid[0]['url']);
        $courseid1 = $courseurlid[0]['id'];
        report_helper::save_selected_report($courseid1, $url1);
> $this->assertDebuggingCalled('save_selected_report() has been deprecated because it is no ' . > 'longer used and will be removed in future versions of Moodle');
$this->assertEquals($USER->course_last_report[$courseid1], $url1); $url2 = new moodle_url($courseurlid[1]['url']); $courseid2 = $courseurlid[1]['id']; report_helper::save_selected_report($courseid2, $url2);
> $this->assertDebuggingCalled('save_selected_report() has been deprecated because it is no ' . > 'longer used and will be removed in future versions of Moodle');
$this->assertEquals($USER->course_last_report[$courseid2], $url2);
< } < < /** < * Testing the report selector dropdown shown. < * < * Verify that the dropdowns have the pages to be displayed. < * < * @return void < */ < public function test_print_report_selector():void { < global $PAGE; < < $this->resetAfterTest(); < < $user = $this->getDataGenerator()->create_user(); < < $PAGE->set_url('/'); < < $course = $this->getDataGenerator()->create_course(); < $PAGE->set_course($course); < < $this->getDataGenerator()->enrol_user($user->id, $course->id, 'teacher'); < < $this->setUser($user); < < ob_start(); < report_helper::print_report_selector('Logs'); < $output = $this->getActualOutput(); < ob_end_clean(); < < $log = '<option value="/report/log/index.php?id=' . $course->id .'" selected>Logs</option>'; < $competency = '<option value="/report/competency/index.php?id=' . $course->id . '" >Competency breakdown</option>'; < $loglive = '<option value="/report/loglive/index.php?id=' . $course->id . '" >Live logs</option>'; < $participation = '<option value="/report/participation/index.php?id=' . $course->id . '" >Course participation</option>'; < $this->assertStringContainsString($log, $output); < $this->assertStringContainsString($competency, $output); < $this->assertStringContainsString($loglive, $output); < $this->assertStringContainsString($participation, $output);
} }