/
NegativeValidatorTest.php
124 lines (105 loc) · 2.85 KB
/
NegativeValidatorTest.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
122
123
124
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Validator\Tests\Constraints;
use Symfony\Component\Validator\Constraints\Negative;
use Symfony\Component\Validator\Constraints\NegativeValidator;
use Symfony\Component\Validator\Test\ConstraintValidatorTestCase;
/**
* @author Jan Schädlich <jan.schaedlich@sensiolabs.de>
*/
class NegativeValidatorTest extends ConstraintValidatorTestCase
{
protected function createValidator()
{
return new NegativeValidator();
}
/**
* @dataProvider getValidValues
*/
public function testValidValues($value)
{
$this->validator->validate($value, new Negative());
$this->assertNoViolation();
}
public function getValidValues()
{
return array(
array(-1),
array(-1.1),
array('-1.1'),
);
}
/**
* @dataProvider getInvalidValues
*/
public function testInvalidValues($value)
{
$constraint = new Negative(array(
'message' => 'myMessage',
));
$this->validator->validate($value, $constraint);
$this->buildViolation('myMessage')
->setParameter('{{ value }}', $value)
->setCode(Negative::IS_POSITIVE_ERROR)
->assertRaised();
}
public function getInvalidValues()
{
return array(
array(1),
array(1.1),
array('1.1'),
);
}
/**
* @dataProvider getZeroValues
*/
public function testZeroIsInvalid($value)
{
$constraint = new Negative(array(
'message' => 'myMessage',
));
$this->validator->validate($value, $constraint);
$this->buildViolation('myMessage')
->setParameter('{{ value }}', $value)
->setCode(Negative::IS_ZERO_ERROR)
->assertRaised();
}
public function getZeroValues()
{
return array(
array(0),
array(0.0),
array(.0),
);
}
/**
* @dataProvider getWrongTypeValues
* @expectedException \Symfony\Component\Validator\Exception\UnexpectedTypeException
*/
public function testItShouldThrowExceptionForWrongType($value)
{
$this->validator->validate($value, new Negative());
}
public function getWrongTypeValues()
{
return array(
array(array('invalid')),
array(array(1)),
array(new \DateTime()),
array(new \stdClass()),
);
}
public function testItShouldDoNothingForNullValue()
{
$this->validator->validate(null, new Negative());
$this->assertNoViolation();
}
}