Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 3.9.x will end* 10 May 2021 (12 months).
  • Bug fixes for security issues in 3.9.x will end* 8 May 2023 (36 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are 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/>.
< defined('MOODLE_INTERNAL') || exit();
> > namespace tool_monitor;
/** * Unit tests for the subscription class. * @since 3.2.0 * * @package tool_monitor * @category test * @copyright 2016 Jake Dallimore <jrhdallimore@gmail.com> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */
< class tool_monitor_subscription_testcase extends advanced_testcase {
> class subscription_test extends \advanced_testcase {
/** * @var \tool_monitor\subscription $subscription object. */ private $subscription; /** * Test set up. */
< public function setUp() {
> public function setUp(): void {
$this->resetAfterTest(true); // Create the mock subscription.
< $sub = new stdClass();
> $sub = new \stdClass();
$sub->id = 100; $sub->name = 'My test rule'; $sub->courseid = 20; $mockbuilder = $this->getMockBuilder('\tool_monitor\subscription');
< $mockbuilder->setMethods(null);
> $mockbuilder->onlyMethods([]);
$mockbuilder->setConstructorArgs(array($sub)); $this->subscription = $mockbuilder->getMock(); } /** * Test for the magic __isset method. */ public function test_magic_isset() { $this->assertEquals(true, isset($this->subscription->name)); $this->assertEquals(true, isset($this->subscription->courseid)); $this->assertEquals(false, isset($this->subscription->ruleid)); } /** * Test for the magic __get method.
< * < * @expectedException coding_exception
*/ public function test_magic_get() { $this->assertEquals(20, $this->subscription->courseid);
> $this->expectException(\coding_exception::class);
$this->subscription->ruleid; } }