[BUGFIX] Fix unit test for NumberRangeValidator
[Packages/TYPO3.CMS.git] / typo3 / sysext / extbase / Tests / Unit / Validation / Validator / BeforeExtbase14 / NumberRangeValidatorTest.php
1 <?php
2 /***************************************************************
3 * Copyright notice
4 *
5 * (c) 2009 Jochen Rau <jochen.rau@typoplanet.de>
6 * All rights reserved
7 *
8 * This class is a backport of the corresponding class of FLOW3.
9 * All credits go to the v5 team.
10 *
11 * This script is part of the TYPO3 project. The TYPO3 project is
12 * free software; you can redistribute it and/or modify
13 * it under the terms of the GNU General Public License as published by
14 * the Free Software Foundation; either version 2 of the License, or
15 * (at your option) any later version.
16 *
17 * The GNU General Public License can be found at
18 * http://www.gnu.org/copyleft/gpl.html.
19 *
20 * This script is distributed in the hope that it will be useful,
21 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
23 * GNU General Public License for more details.
24 *
25 * This copyright notice MUST APPEAR in all copies of the script!
26 ***************************************************************/
27
28 /**
29 * Testcase for the number range validator
30 *
31 * This testcase checks the expected behavior for Extbase < 1.4.0, to make sure
32 * we do not break backwards compatibility.
33 *
34 * @package Extbase
35 * @subpackage extbase
36 * @version $Id: NumberRangeValidator_testcase.php 2428 2010-07-20 10:18:51Z jocrau $
37 */
38 class Tx_Extbase_Tests_Unit_Validation_Validator_BeforeExtbase14_NumberRangeValidatorTest extends Tx_Extbase_Tests_Unit_BaseTestCase {
39
40 /**
41 * @test
42 */
43 public function numberRangeValidatorReturnsTrueForASimpleIntegerInRange() {
44 $numberRangeValidator = new Tx_Extbase_Validation_Validator_NumberRangeValidator();
45 $numberRangeValidator->setOptions(array('startRange' => 0, 'endRange' => 1000));
46
47 $this->assertTrue($numberRangeValidator->isValid(10.5));
48 }
49
50 /**
51 * @test
52 */
53 public function numberRangeValidatorReturnsFalseForANumberOutOfRange() {
54 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
55 $numberRangeValidator->setOptions(array('startRange' => 0, 'endRange' => 1000));
56 $this->assertFalse($numberRangeValidator->isValid(1000.1));
57 }
58
59 /**
60 * @test
61 */
62 public function numberRangeValidatorReturnsTrueForANumberInReversedRange() {
63 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
64 $numberRangeValidator->setOptions(array('startRange' => 1000, 'endRange' => 0));
65 $this->assertTrue($numberRangeValidator->isValid(100));
66 }
67
68 /**
69 * @test
70 */
71 public function numberRangeValidatorReturnsFalseForAString() {
72 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
73 $numberRangeValidator->setOptions(array('startRange' => 0, 'endRange' => 1000));
74 $this->assertFalse($numberRangeValidator->isValid('not a number'));
75 }
76
77 /**
78 * @test
79 */
80 public function numberRangeValidatorCreatesTheCorrectErrorForANumberOutOfRange() {
81 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
82 $numberRangeValidator->expects($this->once())->method('addError')->with('The given subject was not in the valid range (%1$d - %2$d).', 1221561046, array(1, 42));
83 $numberRangeValidator->setOptions(array('startRange' => 1, 'endRange' => 42));
84 $numberRangeValidator->isValid(4711);
85 }
86
87 /**
88 * @test
89 */
90 public function numberRangeValidatorCreatesTheCorrectErrorForAStringSubject() {
91 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
92 $numberRangeValidator->expects($this->once())->method('addError')->with('The given subject was not a valid number.', 1221563685);
93 $numberRangeValidator->setOptions(array('startRange' => 0, 'endRange' => 42));
94 $numberRangeValidator->isValid('this is not between 0 an 42');
95 }
96 }
97
98 ?>