[TASK] Use name-resolution instead of strings where possible: 3
[Packages/TYPO3.CMS.git] / typo3 / sysext / extbase / Tests / Unit / Validation / Validator / FloatValidatorTest.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 float validator
26 *
27 * @license http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public License, version 3 or later
28 */
29 class FloatValidatorTest extends \TYPO3\CMS\Extbase\Tests\Unit\Validation\Validator\AbstractValidatorTestcase {
30
31 protected $validatorClassName = \TYPO3\CMS\Extbase\Validation\Validator\FloatValidator::class;
32
33 public function setup() {
34 $this->validator = $this->getMock($this->validatorClassName, array('translateErrorMessage'));
35 }
36
37 /**
38 * Data provider with valid floats
39 *
40 * @return array
41 * @author Karsten Dambekalns <karsten@typo3.org>
42 */
43 public function validFloats() {
44 return array(
45 array(1029437.234726),
46 array('123.45'),
47 array('+123.45'),
48 array('-123.45'),
49 array('123.45e3'),
50 array(123450.0)
51 );
52 }
53
54 /**
55 * @author Karsten Dambekalns <karsten@typo3.org>
56 * @test
57 * @dataProvider validFloats
58 * @param mixed $float
59 */
60 public function floatValidatorReturnsNoErrorsForAValidFloat($float) {
61 $this->assertFalse($this->validator->validate($float)->hasErrors());
62 }
63
64 /**
65 * Data provider with invalid floats
66 *
67 * @return array
68 * @author Karsten Dambekalns <karsten@typo3.org>
69 */
70 public function invalidFloats() {
71 return array(
72 array(1029437),
73 array('1029437'),
74 array('not a number')
75 );
76 }
77
78 /**
79 * @author Karsten Dambekalns <karsten@typo3.org>
80 * @test
81 * @dataProvider invalidFloats
82 * @param mixed $float
83 */
84 public function floatValidatorReturnsErrorForAnInvalidFloat($float) {
85 $this->assertTrue($this->validator->validate($float)->hasErrors());
86 }
87
88 /**
89 * test
90 *
91 * @author Andreas Förthner <andreas.foerthner@netlogix.de>
92 */
93 public function floatValidatorCreatesTheCorrectErrorForAnInvalidSubject() {
94 $this->assertEquals(1, count($this->validator->validate(123456)->getErrors()));
95 }
96 }