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

< /** < * PHPUnit data generator tests < * < * @package mod_lti < * @category phpunit < * @copyright Copyright (c) 2012 Moodlerooms Inc. (http://www.moodlerooms.com) < * @author Mark Nielsen < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */ < < defined('MOODLE_INTERNAL') || die();
> namespace mod_lti;
/** * PHPUnit data generator testcase * * @package mod_lti * @category phpunit * @copyright Copyright (c) 2012 Moodlerooms Inc. (http://www.moodlerooms.com) * @author Mark Nielsen * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class mod_lti_generator_testcase extends advanced_testcase {
> class generator_test extends \advanced_testcase {
public function test_generator() { global $DB; $this->resetAfterTest(true); $this->assertEquals(0, $DB->count_records('lti')); $course = $this->getDataGenerator()->create_course(); /* * @var mod_lti_generator $generator */ $generator = $this->getDataGenerator()->get_plugin_generator('mod_lti'); $this->assertInstanceOf('mod_lti_generator', $generator); $this->assertEquals('lti', $generator->get_modulename()); $generator->create_instance(array('course' => $course->id)); $generator->create_instance(array('course' => $course->id)); $lti = $generator->create_instance(array('course' => $course->id)); $this->assertEquals(3, $DB->count_records('lti')); $cm = get_coursemodule_from_instance('lti', $lti->id); $this->assertEquals($lti->id, $cm->instance); $this->assertEquals('lti', $cm->modname); $this->assertEquals($course->id, $cm->course);
< $context = context_module::instance($cm->id);
> $context = \context_module::instance($cm->id);
$this->assertEquals($lti->cmid, $context->instanceid); // Test gradebook integration using low level DB access - DO NOT USE IN PLUGIN CODE! $lti = $generator->create_instance(array('course' => $course->id, 'assessed' => 1, 'scale' => 100)); $gitem = $DB->get_record('grade_items', array('courseid' => $course->id, 'itemtype' => 'mod', 'itemmodule' => 'lti', 'iteminstance' => $lti->id)); $this->assertNotEmpty($gitem); $this->assertEquals(100, $gitem->grademax); $this->assertEquals(0, $gitem->grademin); $this->assertEquals(GRADE_TYPE_VALUE, $gitem->gradetype); } }