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

< /** < * Unit tests for grade/report/lib.php. < * < * @package core_grades < * @category phpunit < * @copyright Andrew Nicols <andrew@nicols.co.uk> < * @license http://www.gnu.org/copyleft/gpl.html GNU Public License < */
> namespace core_grades;
defined('MOODLE_INTERNAL') || die(); global $CFG; require_once($CFG->dirroot.'/grade/lib.php'); require_once($CFG->dirroot.'/grade/export/lib.php'); /** * A test class used to test grade_report, the abstract grade report parent class
> * */ > * @package core_grades class core_grade_export_test extends advanced_testcase { > * @category test > * @copyright Andrew Nicols <andrew@nicols.co.uk> /** > * @license http://www.gnu.org/copyleft/gpl.html GNU Public License
< class core_grade_export_test extends advanced_testcase {
> class export_test extends \advanced_testcase {
* * @dataProvider format_feedback_provider * @param string $input The input string to test * @param int $inputformat The format of the input string * @param string $expected The expected result of the format. */ public function test_format_feedback($input, $inputformat, $expected) { $feedback = $this->getMockForAbstractClass( \grade_export::class, [], '', false ); $this->assertEquals( $expected, $feedback->format_feedback((object) [ 'feedback' => $input, 'feedbackformat' => $inputformat, ]) ); } /** * Ensure that feedback is correctly formatted. Test augmented functionality to handle file links */ public function test_format_feedback_with_grade() { $this->resetAfterTest(); $dg = $this->getDataGenerator(); $c1 = $dg->create_course(); $u1 = $dg->create_user();
< $gi1a = new grade_item($dg->create_grade_item(['courseid' => $c1->id]), false);
> $gi1a = new \grade_item($dg->create_grade_item(['courseid' => $c1->id]), false);
$gi1a->update_final_grade($u1->id, 1, 'test'); $contextid = $gi1a->get_context()->id; $gradeid = $gi1a->id; $tests = [ 'Has server based image (HTML)' => [ '<p>See this reference: <img src="@@PLUGINFILE@@/test.img"></p>', FORMAT_HTML, "See this reference: " ], 'Has server based image and more (HTML)' => [ '<p>See <img src="@@PLUGINFILE@@/test.img"> for <em>reference</em></p>', FORMAT_HTML, "See for reference" ], 'Has server based video and more (HTML)' => [ '<p>See <video src="@@PLUGINFILE@@/test.img">video of a duck</video> for <em>reference</em></p>', FORMAT_HTML, 'See video of a duck for reference' ], 'Has server based video with text and more (HTML)' => [ '<p>See <video src="@@PLUGINFILE@@/test.img">@@PLUGINFILE@@/test.img</video> for <em>reference</em></p>', FORMAT_HTML, "See https://www.example.com/moodle/pluginfile.php/$contextid/grade/feedback/$gradeid/test.img for reference" ], 'Multiple videos (HTML)' => [ '<p>See <video src="@@PLUGINFILE@@/test.img">video of a duck</video> and '. '<video src="http://example.com/myimage.jpg">video of a cat</video> for <em>reference</em></p>', FORMAT_HTML, 'See video of a duck and video of a cat for reference' ], ]; $feedback = $this->getMockForAbstractClass( \grade_export::class, [], '', false ); foreach ($tests as $key => $testdetails) { $expected = $testdetails[2]; $input = $testdetails[0]; $inputformat = $testdetails[1]; $this->assertEquals( $expected, $feedback->format_feedback((object) [ 'feedback' => $input, 'feedbackformat' => $inputformat, ], $gi1a), $key ); } } /** * Data provider for the format_feedback tests. * * @return array */ public function format_feedback_provider() : array { return [ 'Basic string (PLAIN)' => [ 'This is an example string', FORMAT_PLAIN, 'This is an example string', ], 'Basic string (HTML)' => [ '<p>This is an example string</p>', FORMAT_HTML, 'This is an example string', ], 'Has image (HTML)' => [ '<p>See this reference: <img src="http://example.com/myimage.jpg"></p>', FORMAT_HTML, 'See this reference: ', ], 'Has image and more (HTML)' => [ '<p>See <img src="http://example.com/myimage.jpg"> for <em>reference</em></p>', FORMAT_HTML, 'See for reference', ], 'Has video and more (HTML)' => [ '<p>See <video src="http://example.com/myimage.jpg">video of a duck</video> for <em>reference</em></p>', FORMAT_HTML, 'See video of a duck for reference', ], 'Multiple videos (HTML)' => [ '<p>See <video src="http://example.com/myimage.jpg">video of a duck</video> and '. '<video src="http://example.com/myimage.jpg">video of a cat</video> for <em>reference</em></p>', FORMAT_HTML, 'See video of a duck and video of a cat for reference' ], 'HTML Looking tags in PLAIN' => [ 'The way you have written the <img thing looks pretty fun >', FORMAT_PLAIN, 'The way you have written the &lt;img thing looks pretty fun &gt;', ], ]; } }