[FEATURE] Add several testcases for validators
[Packages/TYPO3.CMS.git] / typo3 / sysext / form / Tests / Unit / Validation / RequiredValidatorTest.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\RequiredValidator.
29 *
30 * @author Andreas Lappe <a.lappe@kuehlhaus.com>
31 * @package TYPO3
32 * @subpackage form
33 */
34 class RequiredValidatorTest 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\RequiredValidator
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\RequiredValidator(array());
48 }
49
50 public function tearDown() {
51 unset($this->helper, $this->fixture);
52 }
53
54 public function validDataProvider() {
55 return array(
56 'a' => array('a'),
57 'a b' => array('a b'),
58 '"0"' => array('0'),
59 '0' => array(0)
60 );
61 }
62
63 public function invalidDataProvider() {
64 return array(
65 'empty string' => array(''),
66 );
67 }
68
69 /**
70 * @test
71 * @dataProvider validDataProvider
72 */
73 public function isValidForValidDataReturnsTrue($input) {
74 $this->fixture->setFieldName('myRequired');
75 $requestHandlerMock = $this->helper->getRequestHandler(array(
76 'myRequired' => $input
77 ));
78 $this->fixture->injectRequestHandler($requestHandlerMock);
79
80 $this->assertTrue(
81 $this->fixture->isValid()
82 );
83 }
84
85 /**
86 * @test
87 * @dataProvider invalidDataProvider
88 */
89 public function isValidForInvalidDataReturnsFalse($input) {
90 $this->fixture->setFieldName('myRequired');
91 $requestHandlerMock = $this->helper->getRequestHandler(array(
92 'myRequired' => $input
93 ));
94 $this->fixture->injectRequestHandler($requestHandlerMock);
95
96 $this->assertFalse(
97 $this->fixture->isValid()
98 );
99 }
100 }
101 ?>