mirror of
https://github.com/Respect/Validation.git
synced 2026-03-15 14:55:44 +01:00
This is a mid-size refactor that affects several validators. Most prominently, the ones that had an `$identical` parameter to deal with case sensitiveness. This parameter was confusing, effectively making validators such as `Contains` behave very differently for arrays versus strings. In arrays, `$identical` meant "the same type", while it in strings it meant "case sensitive". That parameter was removed, and the default behavior is now to always compare **case sensitive** and strict typing. A document explaining how to combine other validators in order to achieve case _insensitive_ comparisons was added. Additionally, the `Call` validator was refactored back to be suitable to take on the task of being a fast, quick composable validator. With the introduction of `Circuit`, we can shift the responsibility of dealing with possible mismatches to the user. This kind of type handling is demonstrated in how I refactored `Tld` to account for the type mismatch without setting error handlers.
57 lines
1.8 KiB
PHP
57 lines
1.8 KiB
PHP
<?php
|
|
|
|
/*
|
|
* SPDX-License-Identifier: MIT
|
|
* SPDX-FileCopyrightText: (c) Respect Project Contributors
|
|
* SPDX-FileContributor: Alexandre Gomes Gaigalas <alganet@gmail.com>
|
|
* SPDX-FileContributor: Henrique Moody <henriquemoody@gmail.com>
|
|
* SPDX-FileContributor: Kirill Dlussky <kirill@dlussky.ru>
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Respect\Validation\Validators;
|
|
|
|
use PHPUnit\Framework\Attributes\CoversClass;
|
|
use PHPUnit\Framework\Attributes\Group;
|
|
use PHPUnit\Framework\Attributes\Test;
|
|
use Respect\Validation\Exceptions\InvalidValidatorException;
|
|
use Respect\Validation\Test\RuleTestCase;
|
|
|
|
#[Group('validator')]
|
|
#[CoversClass(ContainsAny::class)]
|
|
final class ContainsAnyTest extends RuleTestCase
|
|
{
|
|
#[Test]
|
|
public function itShouldThrowAnExceptionWhenThereAreNoNeedles(): void
|
|
{
|
|
$this->expectException(InvalidValidatorException::class);
|
|
$this->expectExceptionMessage('At least one value must be provided');
|
|
|
|
// @phpstan-ignore-next-line
|
|
new ContainsAny([]);
|
|
}
|
|
|
|
/** @return iterable<array{ContainsAny, mixed}> */
|
|
public static function providerForValidInput(): iterable
|
|
{
|
|
return [
|
|
[new ContainsAny([true]), [true]],
|
|
[new ContainsAny([1]), [1, 2, 3]],
|
|
[new ContainsAny(['foo', true]), ['foo', 'bar']],
|
|
];
|
|
}
|
|
|
|
/** @return iterable<array{ContainsAny, mixed}> */
|
|
public static function providerForInvalidInput(): iterable
|
|
{
|
|
return [
|
|
[new ContainsAny(['foo']), ['bar', 'baz']],
|
|
[new ContainsAny(['foo', 'bar']), ['baz', 'qux']],
|
|
[new ContainsAny(['foo', 'bar']), ['FOO', 'BAR']],
|
|
[new ContainsAny(['foo', 'qux']), 'barbaz'],
|
|
[new ContainsAny([1, 2, 3]), ['1', '2', '3']],
|
|
[new ContainsAny(['word', '@', '/']), 'lorem ipsum'],
|
|
];
|
|
}
|
|
}
|