This repository has been archived by the owner on Jan 30, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 41
/
OptionalParametersFilterTest.php
121 lines (107 loc) · 3.07 KB
/
OptionalParametersFilterTest.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
112
113
114
115
116
117
118
119
120
121
<?php
/**
* @see https://github.com/zendframework/zend-hydrator for the canonical source repository
* @copyright Copyright (c) 2010-2018 Zend Technologies USA Inc. (https://www.zend.com)
* @license https://github.com/zendframework/zend-hydrator/blob/master/LICENSE.md New BSD License
*/
declare(strict_types=1);
namespace ZendTest\Hydrator\Filter;
use InvalidArgumentException;
use PHPUnit\Framework\TestCase;
use Zend\Hydrator\Filter\OptionalParametersFilter;
/**
* Unit tests for {@see OptionalParametersFilter}
*
* @covers \Zend\Hydrator\Filter\OptionalParametersFilter
*/
class OptionalParametersFilterTest extends TestCase
{
/**
* @var OptionalParametersFilter
*/
protected $filter;
/**
* {@inheritDoc}
*/
protected function setUp()
{
$this->filter = new OptionalParametersFilter();
}
/**
* Verifies a list of methods against expected results
*
* @param string $method
* @param bool $expectedResult
*
* @dataProvider methodProvider
*/
public function testMethods($method, $expectedResult)
{
$this->assertSame($expectedResult, $this->filter->filter($method));
}
/**
* Verifies a list of methods against expected results over subsequent calls, checking
* that the filter behaves consistently regardless of cache optimizations
*
* @param string $method
* @param bool $expectedResult
*
* @dataProvider methodProvider
*/
public function testMethodsOnSubsequentCalls($method, $expectedResult)
{
for ($i = 0; $i < 5; $i += 1) {
$this->assertSame($expectedResult, $this->filter->filter($method));
}
}
public function testTriggersExceptionOnUnknownMethod()
{
$this->expectException(InvalidArgumentException::class);
$this->filter->filter(__CLASS__ . '::' . 'nonExistingMethod');
}
/**
* Provides a list of methods to be checked against the filter
*
* @return array
*/
public function methodProvider()
{
return [
[__CLASS__ . '::' . 'methodWithoutParameters', true],
[__CLASS__ . '::' . 'methodWithSingleMandatoryParameter', false],
[__CLASS__ . '::' . 'methodWithSingleOptionalParameter', true],
[__CLASS__ . '::' . 'methodWithMultipleMandatoryParameters', false],
[__CLASS__ . '::' . 'methodWithMultipleOptionalParameters', true],
];
}
/**
* Test asset method
*/
public function methodWithoutParameters()
{
}
/**
* Test asset method
*/
public function methodWithSingleMandatoryParameter($parameter)
{
}
/**
* Test asset method
*/
public function methodWithSingleOptionalParameter($parameter = null)
{
}
/**
* Test asset method
*/
public function methodWithMultipleMandatoryParameters($parameter, $otherParameter)
{
}
/**
* Test asset method
*/
public function methodWithMultipleOptionalParameters($parameter = null, $otherParameter = null)
{
}
}