[FEATURE] Add several testcases for validators
[Packages/TYPO3.CMS.git] / typo3 / sysext / form / Tests / Unit / Validation / InArrayValidatorTest.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\InArrayValidator.
29 *
30 * @author Andreas Lappe <a.lappe@kuehlhaus.com>
31 * @package TYPO3
32 * @subpackage form
33 */
34 class InArrayValidatorTest 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\InArrayValidator
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\InArrayValidator(array('array.' => array(), 'strict' => FALSE));
48 }
49
50 public function tearDown() {
51 unset($this->helper, $this->fixture);
52 }
53
54 public function validArrayProvider() {
55 return array(
56 '12 in (12, 13)' => array(array(array(12, 13), 12))
57 );
58 }
59
60 public function invalidArrayProvider() {
61 return array(
62 '12 in (11, 13)' => array(array(array(11, 13), 12)),
63 );
64 }
65
66 /**
67 * @test
68 * @dataProvider validArrayProvider
69 */
70 public function isValidForValidInputReturnsTrue($input) {
71 $this->fixture->setFieldName('myfield');
72 $this->fixture->setArray($input[0]);
73 $requestHandlerMock = $this->helper->getRequestHandler(array(
74 'myfield' => $input[1]
75 ));
76 $this->fixture->injectRequestHandler($requestHandlerMock);
77
78 $this->assertTrue(
79 $this->fixture->isValid()
80 );
81 }
82
83 /**
84 * @test
85 * @dataProvider invalidArrayProvider
86 */
87 public function isValidForInvalidInputReturnsFalse($input) {
88 $this->fixture->setFieldName('myfield');
89 $this->fixture->setArray($input[0]);
90 $requestHandlerMock = $this->helper->getRequestHandler(array(
91 'myfield' => $input[1]
92 ));
93 $this->fixture->injectRequestHandler($requestHandlerMock);
94
95 $this->assertFalse(
96 $this->fixture->isValid()
97 );
98 }
99
100 /**
101 * @test
102 * @dataProvider validArrayProvider
103 */
104 public function isValidForValidInputWithStrictComparisonReturnsTrue($input) {
105 $this->fixture->setFieldName('myfield');
106 $this->fixture->setArray($input[0]);
107 $this->fixture->setStrict(TRUE);
108 $requestHandlerMock = $this->helper->getRequestHandler(array(
109 'myfield' => $input[1]
110 ));
111 $this->fixture->injectRequestHandler($requestHandlerMock);
112
113 $this->assertTrue(
114 $this->fixture->isValid()
115 );
116 }
117
118 /**
119 * @test
120 * @dataProvider invalidArrayProvider
121 */
122 public function isValidForInvalidInputWithStrictComparisonReturnsFalse($input) {
123 $this->fixture->setFieldName('myfield');
124 $this->fixture->setArray($input[0]);
125 $this->fixture->setStrict(TRUE);
126 $requestHandlerMock = $this->helper->getRequestHandler(array(
127 'myfield' => $input[1]
128 ));
129 $this->fixture->injectRequestHandler($requestHandlerMock);
130
131 $this->assertFalse(
132 $this->fixture->isValid()
133 );
134 }
135 }
136 ?>