Raised DBAL version from 1.1.5 to 1.1.6
[Packages/TYPO3.CMS.git] / typo3 / sysext / extbase / Tests / Validation / Validator / NumberRangeValidator_testcase.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 * @package Extbase
32 * @subpackage extbase
33 * @version $Id: NumberRangeValidator_testcase.php 1408 2009-10-08 13:15:09Z jocrau $
34 */
35 class Tx_Extbase_Validation_Validator_NumberRangeValidator_testcase extends Tx_Extbase_BaseTestCase {
36
37 /**
38 * @test
39 */
40 public function numberRangeValidatorReturnsTrueForASimpleIntegerInRange() {
41 $numberRangeValidator = new Tx_Extbase_Validation_Validator_NumberRangeValidator();
42 $numberRangeValidator->setOptions(array('startRange' => 0, 'endRange' => 1000));
43
44 $this->assertTrue($numberRangeValidator->isValid(10.5));
45 }
46
47 /**
48 * @test
49 */
50 public function numberRangeValidatorReturnsFalseForANumberOutOfRange() {
51 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
52 $numberRangeValidator->setOptions(array('startRange' => 0, 'endRange' => 1000));
53 $this->assertFalse($numberRangeValidator->isValid(1000.1));
54 }
55
56 /**
57 * @test
58 */
59 public function numberRangeValidatorReturnsTrueForANumberInReversedRange() {
60 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
61 $numberRangeValidator->setOptions(array('startRange' => 1000, 'endRange' => 0));
62 $this->assertTrue($numberRangeValidator->isValid(100));
63 }
64
65 /**
66 * @test
67 */
68 public function numberRangeValidatorReturnsFalseForAString() {
69 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
70 $numberRangeValidator->setOptions(array('startRange' => 0, 'endRange' => 1000));
71 $this->assertFalse($numberRangeValidator->isValid('not a number'));
72 }
73
74 /**
75 * @test
76 */
77 public function numberRangeValidatorCreatesTheCorrectErrorForANumberOutOfRange() {
78 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
79 $numberRangeValidator->expects($this->once())->method('addError')->with('The given subject was not in the valid range (1 - 42).', 1221561046);
80 $numberRangeValidator->setOptions(array('startRange' => 1, 'endRange' => 42));
81 $numberRangeValidator->isValid(4711);
82 }
83
84 /**
85 * @test
86 */
87 public function numberRangeValidatorCreatesTheCorrectErrorForAStringSubject() {
88 $numberRangeValidator = $this->getMock('Tx_Extbase_Validation_Validator_NumberRangeValidator', array('addError'), array(), '', FALSE);
89 $numberRangeValidator->expects($this->once())->method('addError')->with('The given subject was not a valid number.', 1221563685);
90 $numberRangeValidator->setOptions(array('startRange' => 0, 'endRange' => 42));
91 $numberRangeValidator->isValid('this is not between 0 an 42');
92 }
93 }
94
95 ?>