* * 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(string $validConsonants): void { $validator = new Consonant(); self::assertTrue($validator->validate($validConsonants)); } /** * @dataProvider providerForInvalidConsonants * @expectedException \Respect\Validation\Exceptions\ConsonantException * * @test * * @param mixed $invalidConsonants */ public function invalidConsonantsShouldFailAndThrowConsonantException($invalidConsonants): void { $validator = new Consonant(); self::assertFalse($validator->validate($invalidConsonants)); $validator->assert($invalidConsonants); } /** * @dataProvider providerAdditionalChars * * @test */ public function additionalCharsShouldBeRespected(string $additional, string $input): void { $validator = new Consonant($additional); self::assertTrue($validator->validate($input)); } /** * @return string[][] */ public function providerAdditionalChars(): array { return [ ['!@#$%^&*(){}', '!@#$%^&*(){} bc dfg'], ['[]?+=/\\-_|"\',<>.', "[]?+=/\\-_|\"',<>. \t \n bc dfg"], ]; } /** * @return string[][] */ public function providerForValidConsonants(): array { return [ ['b'], ['c'], ['d'], ['w'], ['y'], ['y', ''], ['bcdfghklmnp'], ['bcdfghklm np'], ['qrst'], ["\nz\t"], ['zbcxwyrspq'], ]; } /** * @return mixed[][] */ public function providerForInvalidConsonants(): array { return [ [''], [null], ['16'], ['aeiou'], ['a'], ['Foo'], [-50], ['basic'], ]; } }