1f93da3222994f910691a46e5733d7f162ed5880
[Packages/TYPO3.CMS.git] / typo3 / sysext / extbase / Tests / Unit / Validation / Validator / StringValidatorTest.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 string length validator
26 *
27 * @license http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public License, version 3 or later
28 */
29 class StringValidatorTest extends \TYPO3\CMS\Extbase\Tests\Unit\Validation\Validator\AbstractValidatorTestcase
30 {
31 /**
32 * @var string
33 */
34 protected $validatorClassName = \TYPO3\CMS\Extbase\Validation\Validator\StringValidator::class;
35
36 public function setup()
37 {
38 $this->validator = $this->getMockBuilder($this->validatorClassName)
39 ->setMethods(['translateErrorMessage'])
40 ->getMock();
41 }
42
43 /**
44 * @test
45 */
46 public function stringValidatorShouldValidateString()
47 {
48 $this->assertFalse($this->validator->validate('Hello World')->hasErrors());
49 }
50
51 /**
52 * @test
53 */
54 public function stringValidatorShouldReturnErrorIfNumberIsGiven()
55 {
56 $this->assertTrue($this->validator->validate(42)->hasErrors());
57 }
58
59 /**
60 * @test
61 */
62 public function stringValidatorShouldReturnErrorIfObjectWithToStringMethodStringIsGiven()
63 {
64 $className = $this->getUniqueId('TestClass');
65 eval('
66 class ' . $className . ' {
67 public function __toString() {
68 return "ASDF";
69 }
70 }
71 ');
72 $object = new $className();
73 $this->assertTrue($this->validator->validate($object)->hasErrors());
74 }
75 }