You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
170 lines
4.7 KiB
170 lines
4.7 KiB
2 years ago
|
<?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/>.
|
||
|
|
||
|
/**
|
||
|
* std_proxy tests.
|
||
|
*
|
||
|
* @package core_calendar
|
||
|
* @copyright 2017 Cameron Ball <cameron@cameron1729.xyz>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
|
||
|
defined('MOODLE_INTERNAL') || die();
|
||
|
|
||
|
use core_calendar\local\event\proxies\std_proxy;
|
||
|
|
||
|
/**
|
||
|
* std_proxy testcase.
|
||
|
*
|
||
|
* @copyright 2017 Cameron Ball <cameron@cameron1729.xyz>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
class core_calendar_std_proxy_testcase extends advanced_testcase {
|
||
|
/**
|
||
|
* @var \stdClass[] $objects Array of objects to proxy.
|
||
|
*/
|
||
|
public $objects;
|
||
|
|
||
|
public function setUp() {
|
||
|
$this->objects = [
|
||
|
1 => (object) [
|
||
|
'member1' => 'Hello',
|
||
|
'member2' => 1729,
|
||
|
'member3' => 'Something else'
|
||
|
],
|
||
|
5 => (object) [
|
||
|
'member1' => 'Hej',
|
||
|
'member2' => 87539319,
|
||
|
'member3' => 'nagot annat'
|
||
|
]
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test proxying.
|
||
|
*
|
||
|
* @dataProvider test_proxy_testcases()
|
||
|
* @param int $id Object ID.
|
||
|
* @param string $member Object member to retrieve.
|
||
|
* @param mixed $expected Expected value of member.
|
||
|
*/
|
||
|
public function test_proxy($id, $member, $expected) {
|
||
|
$proxy = new std_proxy($id, function($id) {
|
||
|
return $this->objects[$id];
|
||
|
});
|
||
|
|
||
|
$this->assertEquals($proxy->get($member), $expected);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test setting values with a base class.
|
||
|
*
|
||
|
* @dataProvider test_proxy_testcases()
|
||
|
* @param int $id Object ID.
|
||
|
* @param string $member Object member to retrieve.
|
||
|
* @param mixed $storedvalue Value as would be stored externally.
|
||
|
*/
|
||
|
public function test_base_values($id, $member, $storedvalue) {
|
||
|
$proxy = new std_proxy(
|
||
|
$id,
|
||
|
function($id) {
|
||
|
return $this->objects[$id];
|
||
|
},
|
||
|
(object)['member1' => 'should clobber 1']
|
||
|
);
|
||
|
|
||
|
$expected = $member == 'member1' ? 'should clobber 1' : $storedvalue;
|
||
|
$this->assertEquals($proxy->get($member), $expected);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test getting a non existant member.
|
||
|
*
|
||
|
* @dataProvider test_get_set_testcases()
|
||
|
* @param int $id ID of the object being proxied.
|
||
|
*/
|
||
|
public function test_get_invalid_member($id) {
|
||
|
$proxy = new std_proxy($id, function($id) {
|
||
|
return $this->objects[$id];
|
||
|
});
|
||
|
|
||
|
$this->expectException('\core_calendar\local\event\exceptions\member_does_not_exist_exception');
|
||
|
$proxy->get('thisdoesnotexist');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test get proxied instance.
|
||
|
*
|
||
|
* @dataProvider test_get_set_testcases()
|
||
|
* @param int $id Object ID.
|
||
|
*/
|
||
|
public function test_get_proxied_instance($id) {
|
||
|
$proxy = new std_proxy($id, function($id) {
|
||
|
return $this->objects[$id];
|
||
|
});
|
||
|
|
||
|
$this->assertEquals($proxy->get_proxied_instance(), $this->objects[$id]);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test cases for proxying test.
|
||
|
*/
|
||
|
public function test_proxy_testcases() {
|
||
|
return [
|
||
|
'Object 1 member 1' => [
|
||
|
1,
|
||
|
'member1',
|
||
|
'Hello'
|
||
|
],
|
||
|
'Object 1 member 2' => [
|
||
|
1,
|
||
|
'member2',
|
||
|
1729
|
||
|
],
|
||
|
'Object 1 member 3' => [
|
||
|
1,
|
||
|
'member3',
|
||
|
'Something else'
|
||
|
],
|
||
|
'Object 2 member 1' => [
|
||
|
5,
|
||
|
'member1',
|
||
|
'Hej'
|
||
|
],
|
||
|
'Object 2 member 2' => [
|
||
|
5,
|
||
|
'member2',
|
||
|
87539319
|
||
|
],
|
||
|
'Object 3 member 3' => [
|
||
|
5,
|
||
|
'member3',
|
||
|
'nagot annat'
|
||
|
]
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test cases for getting and setting tests.
|
||
|
*/
|
||
|
public function test_get_set_testcases() {
|
||
|
return [
|
||
|
'Object 1' => [1],
|
||
|
'Object 2' => [5]
|
||
|
];
|
||
|
}
|
||
|
}
|