respect-validation/tests/unit/Validators/LengthTest.php
Henrique Moody 81310cc4d9
Rename namespace Rules to Validators
Since that namespace contains our “validators”, naming it as such makes
much more sense.
2026-01-05 17:36:35 +01:00

60 lines
1.7 KiB
PHP

<?php
/*
* Copyright (c) Alexandre Gomes Gaigalas <alganet@gmail.com>
* SPDX-License-Identifier: MIT
*/
declare(strict_types=1);
namespace Respect\Validation\Validators;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\Attributes\Group;
use PHPUnit\Framework\Attributes\Test;
use Respect\Validation\Test\DataProvider as RespectDataProvider;
use Respect\Validation\Test\TestCase;
use Respect\Validation\Test\Validators\Stub;
use function count;
use function mb_strlen;
#[Group('validator')]
#[CoversClass(Length::class)]
final class LengthTest extends TestCase
{
#[Test]
#[DataProvider('providerForNonStringsNorCountable')]
public function itShouldAlwaysInvalidateNonStringsNorCountable(mixed $input): void
{
self::assertInvalidInput(new Length(Stub::any(1)), $input);
}
#[Test]
#[DataProvider('providerForStringTypes')]
public function itShouldValidateStringTypes(string $input): void
{
$wrapped = Stub::pass(1);
$validator = new Length($wrapped);
self::assertValidInput($validator, $input);
self::assertEquals(mb_strlen($input), $wrapped->inputs[0]);
}
#[Test]
#[DataProvider('providerForCountable')]
public function itShouldValidateCountable(mixed $input): void
{
$wrapped = Stub::pass(1);
$validator = new Length($wrapped);
self::assertValidInput($validator, $input);
self::assertEquals(count($input), $wrapped->inputs[0]);
}
public static function providerForNonStringsNorCountable(): RespectDataProvider
{
return self::providerForAnyValues()->without('stringType', 'countable');
}
}