[TASK] Use name-resolution instead of strings where possible: 3
[Packages/TYPO3.CMS.git] / typo3 / sysext / extbase / Tests / Unit / Validation / Validator / NotEmptyValidatorTest.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 not empty validator
26 *
27 * @license http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public License, version 3 or later
28 */
29 class NotEmptyValidatorTest extends \TYPO3\CMS\Extbase\Tests\Unit\Validation\Validator\AbstractValidatorTestcase {
30
31 protected $validatorClassName = \TYPO3\CMS\Extbase\Validation\Validator\NotEmptyValidator::class;
32
33 public function setup() {
34 $this->validator = $this->getMock($this->validatorClassName, array('translateErrorMessage'));
35 }
36
37 /**
38 * @test
39 * @author Andreas Förthner <andreas.foerthner@netlogix.de>
40 */
41 public function notEmptyValidatorReturnsNoErrorForASimpleString() {
42 $this->assertFalse($this->validator->validate('a not empty string')->hasErrors());
43 }
44
45 /**
46 * @test
47 * @author Andreas Förthner <andreas.foerthner@netlogix.de>
48 */
49 public function notEmptyValidatorReturnsErrorForAnEmptyString() {
50 $this->assertTrue($this->validator->validate('')->hasErrors());
51 }
52
53 /**
54 * @test
55 * @author Andreas Förthner <andreas.foerthner@netlogix.de>
56 */
57 public function notEmptyValidatorReturnsErrorForANullValue() {
58 $this->assertTrue($this->validator->validate(NULL)->hasErrors());
59 }
60
61 /**
62 * @test
63 * @author Andreas Förthner <andreas.foerthner@netlogix.de>
64 */
65 public function notEmptyValidatorCreatesTheCorrectErrorForAnEmptySubject() {
66 $this->assertEquals(1, count($this->validator->validate('')->getErrors()));
67 }
68
69 /**
70 * @test
71 * @author Andreas Förthner <andreas.foerthner@netlogix.de>
72 */
73 public function notEmptyValidatorCreatesTheCorrectErrorForANullValue() {
74 $this->assertEquals(1, count($this->validator->validate(NULL)->getErrors()));
75 }
76
77 /**
78 * @test
79 * @author Ingo Pfennigstorf <i.pfennigstorf@gmail.com>
80 */
81 public function notEmptyValidatorWorksForEmptyArrays() {
82 $this->assertTrue($this->validator->validate(array())->hasErrors());
83 $this->assertFalse($this->validator->validate(array(1 => 2))->hasErrors());
84 }
85
86 /**
87 * @test
88 * @author Ingo Pfennigstorf <i.pfennigstorf@gmail.com>
89 */
90 public function notEmptyValidatorWorksForEmptyCountableObjects() {
91 $this->assertTrue($this->validator->validate(new \SplObjectStorage())->hasErrors());
92 }
93
94 /**
95 * @test
96 * @author Alexander Schnitzler <alex.schnitzler@typovision.de>
97 */
98 public function notEmptyValidatorWorksForNotEmptyCountableObjects() {
99 $countableObject = new \SplObjectStorage();
100 $countableObject->attach(new \StdClass());
101 $this->assertFalse($this->validator->validate($countableObject)->hasErrors());
102 }
103 }