* * 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 Respect\Validation\Test\TestCase; /** * @group rule * @covers \Respect\Validation\Exceptions\ConsonantException * @covers \Respect\Validation\Rules\AbstractFilterRule * @covers \Respect\Validation\Rules\Consonant * * @author Gabriel Caruso * @author Henrique Moody * @author Kleber Hamada Sato * @author Nick Lombard * @author Pascal Borreli */ class ConsonantTest extends TestCase { /** * @dataProvider providerForValidConsonants * * @test */ public function validDataWithConsonantsShouldReturnTrue($validConsonants, $additional = ''): void { $validator = new Consonant($additional); self::assertTrue($validator->validate($validConsonants)); } /** * @dataProvider providerForInvalidConsonants * @expectedException \Respect\Validation\Exceptions\ConsonantException * * @test */ public function invalidConsonantsShouldFailAndThrowConsonantException($invalidConsonants, $additional = ''): void { $validator = new Consonant($additional); self::assertFalse($validator->validate($invalidConsonants)); $validator->assert($invalidConsonants); } /** * @dataProvider providerAdditionalChars * * @test */ public function additionalCharsShouldBeRespected($additional, $query): void { $validator = new Consonant($additional); self::assertTrue($validator->validate($query)); } public function providerAdditionalChars() { return [ ['!@#$%^&*(){}', '!@#$%^&*(){} bc dfg'], ['[]?+=/\\-_|"\',<>.', "[]?+=/\\-_|\"',<>. \t \n bc dfg"], ]; } public function providerForValidConsonants() { return [ ['b'], ['c'], ['d'], ['w'], ['y'], ['y', ''], ['bcdfghklmnp'], ['bcdfghklm np'], ['qrst'], ["\nz\t"], ['zbcxwyrspq'], ]; } public function providerForInvalidConsonants() { return [ [''], [null], ['16'], ['aeiou'], ['a'], ['Foo'], [-50], ['basic'], ]; } }