respect-validation/tests/unit/Rules/CircuitTest.php
Henrique Moody 0c07060a04
Rename "Consecutive" to "Circuit"
The "Consecutive" rule is now renamed to "Circuit" to better reflect its
behavior of stopping at the first failure. I also favour this name
because it's much shorter.
2024-12-20 16:53:56 +01:00

63 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\Rules;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\Attributes\Group;
use PHPUnit\Framework\Attributes\Test;
use Respect\Validation\Test\Rules\Stub;
use Respect\Validation\Test\TestCase;
use function rand;
#[Group('rule')]
#[CoversClass(Circuit::class)]
final class CircuitTest extends TestCase
{
#[Test]
#[DataProvider('providerForAnyValues')]
public function itShouldValidateInputWhenAllRulesValidatesTheInput(mixed $input): void
{
self::assertValidInput(new Circuit(Stub::pass(1), Stub::pass(1)), $input);
}
#[Test]
#[DataProvider('providerForFailingRules')]
public function itShouldExecuteRulesInSequenceUntilOneFails(Stub ...$stub): void
{
$rule = new Circuit(...$stub);
self::assertInvalidInput($rule, rand());
}
#[Test]
public function itShouldReturnTheResultOfTheFailingRule(): void
{
$input = rand();
$rule = new Circuit(Stub::fail(1), Stub::daze());
$actual = $rule->evaluate($input);
$expected = Stub::fail(1)->evaluate($input);
self::assertEquals($expected, $actual);
}
/** @return array<array<Stub>> */
public static function providerForFailingRules(): array
{
return [
'first fails' => [Stub::fail(1), Stub::daze()],
'second fails' => [Stub::pass(1), Stub::fail(1), Stub::daze()],
'third fails' => [Stub::pass(1), Stub::fail(1), Stub::fail(1), Stub::daze(), Stub::daze()],
];
}
}