respect-validation/tests/unit/Rules/AlnumTest.php
Henrique Moody 692d317cbe
Update the validation engine of filter-based rules
While I migrate them, I also renamed "AbstractFilterRule" to "Filter"
because that's a much simpler name, and I would like to stop having
"Abstract" and "Interfaces" as part of the name of the classes.

Signed-off-by: Henrique Moody <henriquemoody@gmail.com>
2024-02-22 17:21:49 +01:00

65 lines
2 KiB
PHP

<?php
/*
* Copyright (c) Alexandre Gomes Gaigalas <alganet@gmail.com>
* SPDX-License-Identifier: MIT
*/
declare(strict_types=1);
namespace Respect\Validation\Rules;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\Group;
use Respect\Validation\Test\RuleTestCase;
use stdClass;
#[Group('rule')]
#[CoversClass(Alnum::class)]
final class AlnumTest extends RuleTestCase
{
/** @return iterable<array{Alnum, mixed}> */
public static function providerForValidInput(): iterable
{
return [
[new Alnum(), 'alganet'],
[new Alnum('- ! :'), 'foo :- 123 !'],
[new Alnum('0-9'), '0alg-anet0'],
[new Alnum(), '1'],
[new Alnum(), 'a'],
[new Alnum(), 'foobar'],
[new Alnum('_'), 'rubinho_'],
[new Alnum('.'), 'google.com'],
[new Alnum(' '), 'alganet alganet'],
[new Alnum(), 0],
[new Alnum('!@#$%^&*(){}'), '!@#$%^&*(){}abc123'],
[new Alnum('[]?+=/\\-_|"\',<>.'), '[]?+=/\\-_|"\',<>.abc123'],
[new Alnum("[]?+=/\\-_|\"',<>. \t\n"), "abc[]?+=/\\-_|\"',<>. \t\n123"],
[new Alnum('-', '*'), 'a-1*d'],
];
}
/** @return iterable<array{Alnum, mixed}> */
public static function providerForInvalidInput(): iterable
{
return [
[new Alnum(), ''],
[new Alnum(), 'number 100%'],
[new Alnum('%'), 'number 100%'],
[new Alnum(), '@#$'],
[new Alnum(), '_'],
[new Alnum(), 'dgç'],
[new Alnum(), 1e21],
[new Alnum(), null],
[new Alnum(), new stdClass()],
[new Alnum(), []],
[new Alnum('%'), 'number 100%'],
[new Alnum(), "\t"],
[new Alnum(), "\n"],
[new Alnum(), "\nabc"],
[new Alnum(), "\tdef"],
[new Alnum(), "\nabc \t"],
[new Alnum(), 'alganet alganet'],
];
}
}