[TASK] Use name-resolution instead of strings where possible: 3
[Packages/TYPO3.CMS.git] / typo3 / sysext / extbase / Tests / Unit / Validation / Validator / EmailAddressValidatorTest.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 * Test case
26 */
27 class EmailAddressValidatorTest extends \TYPO3\CMS\Core\Tests\UnitTestCase {
28
29 /**
30 * Data provider with valid email addresses
31 *
32 * @return array
33 */
34 public function validAddresses() {
35 return array(
36 array('andreas.foerthner@netlogix.de'),
37 array('user@localhost.localdomain'),
38 array('info@guggenheim.museum'),
39 array('just@test.invalid'),
40 array('just+spam@test.de'),
41 );
42 }
43
44 /**
45 * @test
46 * @dataProvider validAddresses
47 * @param mixed $address
48 */
49 public function emailAddressValidatorReturnsNoErrorsForAValidEmailAddress($address) {
50 /** @var \TYPO3\CMS\Extbase\Validation\Validator\EmailAddressValidator|\PHPUnit_Framework_MockObject_MockObject $subject */
51 $subject = $this->getMock(\TYPO3\CMS\Extbase\Validation\Validator\EmailAddressValidator::class, array('translateErrorMessage'));
52 $this->assertFalse($subject->validate($address)->hasErrors());
53 }
54
55 /**
56 * Data provider with invalid email addresses
57 *
58 * @return array
59 */
60 public function invalidAddresses() {
61 return array(
62 array('andreas.foerthner@'),
63 array('@typo3.org'),
64 array('someone@typo3.'),
65 array('local@192.168.2'),
66 array('local@192.168.270.1'),
67 array('foo@bar.com' . chr(0)),
68 array('foo@bar.org' . chr(10)),
69 array('andreas@foerthner@example.com'),
70 array('some@one.net ')
71 );
72 }
73
74 /**
75 * @test
76 * @dataProvider invalidAddresses
77 * @param mixed $address
78 */
79 public function emailAddressValidatorReturnsFalseForAnInvalidEmailAddress($address) {
80 /** @var \TYPO3\CMS\Extbase\Validation\Validator\EmailAddressValidator|\PHPUnit_Framework_MockObject_MockObject $subject */
81 $subject = $this->getMock(\TYPO3\CMS\Extbase\Validation\Validator\EmailAddressValidator::class, array('translateErrorMessage'));
82 $this->assertTrue($subject->validate($address)->hasErrors());
83 }
84
85 /**
86 * @test
87 */
88 public function emailValidatorCreatesTheCorrectErrorForAnInvalidEmailAddress() {
89 /** @var \TYPO3\CMS\Extbase\Validation\Validator\EmailAddressValidator|\PHPUnit_Framework_MockObject_MockObject $subject */
90 $subject = $this->getMock(\TYPO3\CMS\Extbase\Validation\Validator\EmailAddressValidator::class, array('translateErrorMessage'));
91 $this->assertEquals(1, count($subject->validate('notAValidMail@Address')->getErrors()));
92 }
93 }