[FEATURE] Add several testcases for validators
[Packages/TYPO3.CMS.git] / typo3 / sysext / form / Tests / Unit / Validation / DigitValidatorTest.php
1 <?php
2 namespace TYPO3\CMS\Form\Tests\Unit\Validation;
3 /***************************************************************
4 * Copyright notice
5 *
6 * (c) 2012 Andreas Lappe <a.lappe@kuehlhaus.com>, kuehlhaus AG
7 *
8 * All rights reserved
9 *
10 * This script is part of the TYPO3 project. The TYPO3 project is
11 * free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; either version 2 of the License, or
14 * (at your option) any later version.
15 *
16 * The GNU General Public License can be found at
17 * http://www.gnu.org/copyleft/gpl.html.
18 *
19 * This script is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
23 *
24 * This copyright notice MUST APPEAR in all copies of the script!
25 ***************************************************************/
26
27 /**
28 * Test case for class \TYPO3\CMS\Form\Validation\DigitValidator.
29 *
30 * @author Andreas Lappe <a.lappe@kuehlhaus.com>
31 * @package TYPO3
32 * @subpackage form
33 */
34 class DigitValidatorTest extends \TYPO3\CMS\Extbase\Tests\Unit\BaseTestCase {
35 /**
36 * @var \TYPO3\CMS\Form\Tests\Unit\Validation\Helper
37 */
38 protected $helper;
39
40 /**
41 * @var \TYPO3\CMS\Form\Validation\DigitValidator
42 */
43 protected $fixture;
44
45 public function setUp() {
46 $this->helper = new \TYPO3\CMS\Form\Tests\Unit\Validation\Helper();
47 $this->fixture = new \TYPO3\CMS\Form\Validation\DigitValidator(array());
48 }
49
50 public function tearDown() {
51 unset($this->helper, $this->fixture);
52 }
53
54 public function validDigitProvider() {
55 return array(
56 'stringified integer' => array('2012'),
57 'stringified integer with leading zeros' => array('0002'),
58 );
59 }
60
61 public function invalidDigitProvider() {
62 return array(
63 'stringified float' => array('0.2012'),
64 'stringified scientific' => array('1.9E+11')
65 );
66 }
67
68 /**
69 * @test
70 * @dataProvider validDigitProvider
71 */
72 public function isValidForValidInputReturnsTrue($input) {
73 $this->fixture->setFieldName('myDigit');
74 $requestHandlerMock = $this->helper->getRequestHandler(array(
75 'myDigit' => $input
76 ));
77 $this->fixture->injectRequestHandler($requestHandlerMock);
78
79 $this->assertTrue(
80 $this->fixture->isValid()
81 );
82 }
83
84 /**
85 * @test
86 * @dataProvider invalidDigitProvider
87 */
88 public function isValidForInvalidInputReturnsFalse($input) {
89 $this->fixture->setFieldName('myDigit');
90 $requestHandlerMock = $this->helper->getRequestHandler(array(
91 'myDigit' => $input
92 ));
93 $this->fixture->injectRequestHandler($requestHandlerMock);
94
95 $this->assertFalse(
96 $this->fixture->isValid()
97 );
98 }
99 }
100 ?>