forked from moodle/moodle
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patharea_category_test.php
111 lines (97 loc) · 3.87 KB
/
area_category_test.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<?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/>.
namespace core_search;
/**
* Area category unit tests.
*
* @package core_search
* @copyright 2018 Dmitrii Metelkin <[email protected]>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class area_category_test extends \advanced_testcase {
/**
* A helper function to get a mocked search area.
* @param string $areaid
*
* @return \PHPUnit\Framework\MockObject\MockObject
*/
protected function get_mocked_area($areaid) {
$builder = $this->getMockBuilder('\core_search\base');
$builder->disableOriginalConstructor();
$builder->onlyMethods(array('get_area_id'));
$area = $builder->getMockForAbstractClass();
$area->method('get_area_id')->willReturn($areaid);
return $area;
}
/**
* A helper function to get a list of search areas.
*
* @return array
*/
protected function get_areas() {
$areas = [];
$areas[] = $this->get_mocked_area('area1');
$areas[] = 'String';
$areas[] = 1;
$areas[] = '12';
$areas[] = true;
$areas[] = false;
$areas[] = null;
$areas[] = [$this->get_mocked_area('area2')];
$areas[] = $this;
$areas[] = new \stdClass();
$areas[] = $this->get_mocked_area('area3');
$areas[] = $this->get_mocked_area('area4');
return $areas;
}
/**
* Test default values.
*/
public function test_default_values() {
$category = new \core_search\area_category('test_name', 'test_visiblename');
$this->assertEquals('test_name', $category->get_name());
$this->assertEquals('test_visiblename', $category->get_visiblename());
$this->assertEquals(0, $category->get_order());
$this->assertEquals([], $category->get_areas());
}
/**
* Test that all get functions work as expected.
*/
public function test_getters() {
$category = new \core_search\area_category('test_name', 'test_visiblename', 4, $this->get_areas());
$this->assertEquals('test_name', $category->get_name());
$this->assertEquals('test_visiblename', $category->get_visiblename());
$this->assertEquals(4, $category->get_order());
$this->assertTrue(is_array($category->get_areas()));
$this->assertCount(3, $category->get_areas());
$this->assertTrue(key_exists('area1', $category->get_areas()));
$this->assertTrue(key_exists('area3', $category->get_areas()));
$this->assertTrue(key_exists('area4', $category->get_areas()));
}
/**
* Test that a list of areas could be set correctly.
*/
public function test_list_of_areas_could_be_set() {
$category = new \core_search\area_category('test_name', 'test_visiblename');
$this->assertEquals([], $category->get_areas());
$category->set_areas($this->get_areas());
$this->assertTrue(is_array($category->get_areas()));
$this->assertCount(3, $category->get_areas());
$this->assertTrue(key_exists('area1', $category->get_areas()));
$this->assertTrue(key_exists('area3', $category->get_areas()));
$this->assertTrue(key_exists('area4', $category->get_areas()));
}
}