[TASK] Use name-resolution instead of strings where possible: 3
[Packages/TYPO3.CMS.git] / typo3 / sysext / extbase / Tests / Unit / Validation / Validator / IntegerValidatorTest.php
1 <?php
2 namespace TYPO3\CMS\Extbase\Tests\Unit\Validation\Validator;
3
4 /* *
5 * This script belongs to the Extbase framework. *
6 * *
7 * It is free software; you can redistribute it and/or modify it under *
8 * the terms of the GNU Lesser General Public License as published by the *
9 * Free Software Foundation, either version 3 of the License, or (at your *
10 * option) any later version. *
11 * *
12 * This script is distributed in the hope that it will be useful, but *
13 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHAN- *
14 * TABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser *
15 * General Public License for more details. *
16 * *
17 * You should have received a copy of the GNU Lesser General Public *
18 * License along with the script. *
19 * If not, see http://www.gnu.org/licenses/lgpl.html *
20 * *
21 * The TYPO3 project - inspiring people to share! *
22 * */
23
24 /**
25 * Testcase for the integer validator
26 *
27 * @license http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public License, version 3 or later
28 */
29 class IntegerValidatorTest extends \TYPO3\CMS\Extbase\Tests\Unit\Validation\Validator\AbstractValidatorTestcase {
30
31 protected $validatorClassName = \TYPO3\CMS\Extbase\Validation\Validator\IntegerValidator::class;
32
33 public function setup() {
34 $this->validator = $this->getMock($this->validatorClassName, array('translateErrorMessage'));
35 }
36
37 /**
38 * Data provider with valid integers
39 *
40 * @return array
41 * @author Karsten Dambekalns <karsten@typo3.org>
42 */
43 public function validIntegers() {
44 return array(
45 array(1029437),
46 array('12345'),
47 array('+12345'),
48 array('-12345')
49 );
50 }
51
52 /**
53 * @author Karsten Dambekalns <karsten@typo3.org>
54 * @test
55 * @dataProvider validIntegers
56 * @param mixed $integer
57 */
58 public function integerValidatorReturnsNoErrorsForAValidInteger($integer) {
59 $this->assertFalse($this->validator->validate($integer)->hasErrors());
60 }
61
62 /**
63 * Data provider with invalid integers
64 *
65 * @return array
66 * @author Karsten Dambekalns <karsten@typo3.org>
67 */
68 public function invalidIntegers() {
69 return array(
70 array('not a number'),
71 array(3.1415),
72 array('12345.987')
73 );
74 }
75
76 /**
77 * @author Karsten Dambekalns <karsten@typo3.org>
78 * @test
79 * @dataProvider invalidIntegers
80 * @param mixed $invalidInteger
81 */
82 public function integerValidatorReturnsErrorForAnInvalidInteger($invalidInteger) {
83 $this->assertTrue($this->validator->validate($invalidInteger)->hasErrors());
84 }
85
86 /**
87 * @test
88 * @author Andreas Förthner <andreas.foerthner@netlogix.de>
89 */
90 public function integerValidatorCreatesTheCorrectErrorForAnInvalidSubject() {
91 $this->assertEquals(1, count($this->validator->validate('not a number')->getErrors()));
92 }
93 }