mirror of
https://github.com/Respect/Validation.git
synced 2024-06-08 00:32:16 +02:00
d1f108dc87
This commit will ensure that all rules that cannot be created because of invalid arguments in the constructor will throw the InvalidRuleConstructorException. It will also make ComponentException extend LogicException, which makes it easier to determine that the client has improperly used the library. I also introduced some tests for two exceptions with logic in their constructor. Signed-off-by: Henrique Moody <henriquemoody@gmail.com>
66 lines
2.1 KiB
PHP
66 lines
2.1 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 PHPUnit\Framework\Attributes\Test;
|
|
use Respect\Validation\Exceptions\InvalidRuleConstructorException;
|
|
use Respect\Validation\Test\RuleTestCase;
|
|
|
|
use const FILTER_FLAG_HOSTNAME;
|
|
use const FILTER_FLAG_QUERY_REQUIRED;
|
|
use const FILTER_SANITIZE_EMAIL;
|
|
use const FILTER_VALIDATE_BOOLEAN;
|
|
use const FILTER_VALIDATE_DOMAIN;
|
|
use const FILTER_VALIDATE_EMAIL;
|
|
use const FILTER_VALIDATE_FLOAT;
|
|
use const FILTER_VALIDATE_INT;
|
|
use const FILTER_VALIDATE_URL;
|
|
|
|
#[Group('rule')]
|
|
#[CoversClass(FilterVar::class)]
|
|
final class FilterVarTest extends RuleTestCase
|
|
{
|
|
#[Test]
|
|
public function itShouldThrowsExceptionWhenFilterIsNotValid(): void
|
|
{
|
|
$this->expectException(InvalidRuleConstructorException::class);
|
|
$this->expectExceptionMessage('Cannot accept the given filter');
|
|
|
|
new FilterVar(FILTER_SANITIZE_EMAIL);
|
|
}
|
|
|
|
/** @return iterable<array{FilterVar, mixed}> */
|
|
public static function providerForValidInput(): iterable
|
|
{
|
|
return [
|
|
[new FilterVar(FILTER_VALIDATE_INT), '12345'],
|
|
[new FilterVar(FILTER_VALIDATE_EMAIL), 'example@example.com'],
|
|
[new FilterVar(FILTER_VALIDATE_FLOAT), 1.5],
|
|
[new FilterVar(FILTER_VALIDATE_BOOLEAN), 'On'],
|
|
[new FilterVar(FILTER_VALIDATE_URL, FILTER_FLAG_QUERY_REQUIRED), 'http://example.com?foo=bar'],
|
|
[new FilterVar(FILTER_VALIDATE_DOMAIN), 'example.com'],
|
|
[new FilterVar(FILTER_VALIDATE_INT), '0'],
|
|
];
|
|
}
|
|
|
|
/** @return iterable<array{FilterVar, mixed}> */
|
|
public static function providerForInvalidInput(): iterable
|
|
{
|
|
return [
|
|
[new FilterVar(FILTER_VALIDATE_INT), 1.4],
|
|
[new FilterVar(FILTER_VALIDATE_URL, FILTER_FLAG_QUERY_REQUIRED), 'http://example.com'],
|
|
[new FilterVar(FILTER_VALIDATE_DOMAIN), '.com'],
|
|
[new FilterVar(FILTER_VALIDATE_DOMAIN, FILTER_FLAG_HOSTNAME), '@local'],
|
|
];
|
|
}
|
|
}
|