respect-validation/tests/unit/Rules/PunctTest.php
Henrique Moody 9e7571fb98
Add missing "@author" annotations
This commit will make sure that every class, interface, or trait will
have the "@author" annotation in it.

In order to create a list of authors, I used the "git blame" command,
which means that if someone changed or even created the file but does
not have any remaining line will not be shown in the list; it's a
trade-off worth but it is worth it. The other way to do it would be
carefully checking each file.

Signed-off-by: Henrique Moody <henriquemoody@gmail.com>
2018-11-25 18:08:44 +01:00

99 lines
2.4 KiB
PHP

<?php
/*
* This file is part of Respect/Validation.
*
* (c) Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
*
* For the full copyright and license information, please view the "LICENSE.md"
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Respect\Validation\Rules;
use PHPUnit\Framework\TestCase;
/**
* @group rule
* @covers \Respect\Validation\Exceptions\PunctException
* @covers \Respect\Validation\Rules\AbstractFilterRule
* @covers \Respect\Validation\Rules\Punct
*
* @author Andre Ramaciotti <andre@ramaciotti.com>
* @author Gabriel Caruso <carusogabriel34@gmail.com>
* @author Henrique Moody <henriquemoody@gmail.com>
* @author Nick Lombard <github@jigsoft.co.za>
* @author Pascal Borreli <pascal@borreli.com>
*/
class PunctTest extends TestCase
{
/**
* @dataProvider providerForValidPunct
*
* @test
*/
public function validDataWithPunctShouldReturnTrue($validPunct, $additional = ''): void
{
$validator = new Punct($additional);
self::assertTrue($validator->validate($validPunct));
}
/**
* @dataProvider providerForInvalidPunct
* @expectedException \Respect\Validation\Exceptions\PunctException
*
* @test
*/
public function invalidPunctShouldFailAndThrowPunctException($invalidPunct, $additional = ''): void
{
$validator = new Punct($additional);
self::assertFalse($validator->validate($invalidPunct));
$validator->assert($invalidPunct);
}
/**
* @dataProvider providerAdditionalChars
*
* @test
*/
public function additionalCharsShouldBeRespected($additional, $query): void
{
$validator = new Punct($additional);
self::assertTrue($validator->validate($query));
}
public function providerAdditionalChars()
{
return [
['abc123 ', '!@#$%^&*(){} abc 123'],
["abc123 \t\n", "[]?+=/\\-_|\"',<>. \t \n abc 123"],
];
}
public function providerForValidPunct()
{
return [
['.'],
[',;:'],
['-@#$*'],
['()[]{}'],
];
}
public function providerForInvalidPunct()
{
return [
[''],
['16-50'],
['a'],
[' '],
['Foo'],
['12.1'],
['-12'],
[-12],
['( )_{}'],
];
}
}