respect-validation/tests/unit/Rules/PeselTest.php
Danilo Correa 719f12a424
Increase code coverage of some rules
We were not thoroughly testing quite a few rules, especially the
constructor of some of them.

This commit increases the code coverage, ensuring almost every single
line in the "Rules" namespace is covered.
2024-04-23 16:01:55 +02:00

59 lines
1.4 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(Pesel::class)]
final class PeselTest extends RuleTestCase
{
/** @return iterable<array{Pesel, mixed}> */
public static function providerForValidInput(): iterable
{
$rule = new Pesel();
return [
[$rule, 0x4EADCD168], // 0x4EADCD168 === 21120209256
[$rule, 49040501580],
[$rule, '49040501580'],
[$rule, '39012110375'],
[$rule, '50083014540'],
[$rule, '69090515504'],
[$rule, '21120209256'],
[$rule, '01320613891'],
];
}
/** @return iterable<array{Pesel, mixed}> */
public static function providerForInvalidInput(): iterable
{
$rule = new Pesel();
return [
[$rule, null],
[$rule, []],
[$rule, new stdClass()],
[$rule, '1'],
[$rule, '22'],
[$rule, 'PESEL'],
[$rule, '0x4EADCD168'],
[$rule, 'PESEL123456'],
[$rule, '690905155.4'],
[$rule, '21120209251'],
[$rule, '21120209250'],
[$rule, '01320613890'],
];
}
}