[!!!][TASK] Extract testing framework for TYPO3
[Packages/TYPO3.CMS.git] / typo3 / sysext / extbase / Tests / Unit / Validation / Validator / NumberRangeValidatorTest.php
1 <?php
2 namespace TYPO3\CMS\Extbase\Tests\Unit\Validation\Validator;
3
4 /* *
5 * This script belongs to the Extbase framework. *
6 * *
7 * It is free software; you can redistribute it and/or modify it under *
8 * the terms of the GNU Lesser General Public License as published by the *
9 * Free Software Foundation, either version 3 of the License, or (at your *
10 * option) any later version. *
11 * *
12 * This script is distributed in the hope that it will be useful, but *
13 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHAN- *
14 * TABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser *
15 * General Public License for more details. *
16 * *
17 * You should have received a copy of the GNU Lesser General Public *
18 * License along with the script. *
19 * If not, see http://www.gnu.org/licenses/lgpl.html *
20 * *
21 * The TYPO3 project - inspiring people to share! *
22 * */
23
24 /**
25 * Test case
26 */
27 class NumberRangeValidatorTest extends \TYPO3\CMS\Components\TestingFramework\Core\UnitTestCase
28 {
29 protected $validatorClassName = \TYPO3\CMS\Extbase\Validation\Validator\NumberRangeValidator::class;
30
31 /**
32 * @test
33 */
34 public function numberRangeValidatorReturnsNoErrorForASimpleIntegerInRange()
35 {
36 $options = ['minimum' => 0, 'maximum' => 1000];
37 $validator = $this->getMockBuilder($this->validatorClassName)
38 ->setMethods(['dummy'])
39 ->setConstructorArgs([$options])
40 ->getMock();
41 $this->assertFalse($validator->validate(10.5)->hasErrors());
42 }
43
44 /**
45 * @test
46 */
47 public function numberRangeValidatorReturnsErrorForANumberOutOfRange()
48 {
49 $options = ['minimum' => 0, 'maximum' => 1000];
50 $validator = $this->getMockBuilder($this->validatorClassName)
51 ->setMethods(['translateErrorMessage'])
52 ->setConstructorArgs([$options])
53 ->getMock();
54 $this->assertTrue($validator->validate(1000.1)->hasErrors());
55 }
56
57 /**
58 * @test
59 */
60 public function numberRangeValidatorReturnsNoErrorForANumberInReversedRange()
61 {
62 $options = ['minimum' => 1000, 'maximum' => 0];
63 $validator = $this->getMockBuilder($this->validatorClassName)
64 ->setMethods(['dummy'])
65 ->setConstructorArgs([$options])
66 ->getMock();
67 $this->assertFalse($validator->validate(100)->hasErrors());
68 }
69
70 /**
71 * @test
72 */
73 public function numberRangeValidatorReturnsErrorForAString()
74 {
75 $options = ['minimum' => 0, 'maximum' => 1000];
76 $validator = $this->getMockBuilder($this->validatorClassName)
77 ->setMethods(['translateErrorMessage'])
78 ->setConstructorArgs([$options])
79 ->getMock();
80 $this->assertTrue($validator->validate('not a number')->hasErrors());
81 }
82 }