mirror of
https://github.com/Respect/Validation.git
synced 2026-03-17 07:45:45 +01:00
After renaming rules to validatores, it doesn't make sense to keep on having that exception. I renamed it to a more cleaner name, not mentioning the constructor because I think that if the constructor is not valid, the validator is not valid, hence the name I chose.
41 lines
1.4 KiB
PHP
41 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\Exceptions;
|
|
|
|
use PHPUnit\Framework\Attributes\CoversClass;
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
|
use PHPUnit\Framework\Attributes\Test;
|
|
use Respect\Validation\Test\TestCase;
|
|
|
|
#[CoversClass(InvalidValidatorException::class)]
|
|
final class InvalidValidatorExceptionTest extends TestCase
|
|
{
|
|
/** @param array<string|array<string>> $arguments */
|
|
#[Test]
|
|
#[DataProvider('providerForMessages')]
|
|
public function itShouldCreateMessageForWithString(string $expect, string $format, array $arguments): void
|
|
{
|
|
$exception = new InvalidValidatorException($format, ...$arguments);
|
|
|
|
self::assertEquals($expect, $exception->getMessage());
|
|
}
|
|
|
|
/** @return array<string, array{0: string, 1: string, 2: array<string|array<string>>}> */
|
|
public static function providerForMessages(): array
|
|
{
|
|
return [
|
|
'with 1 argument' => ['-arg-', '-%s-', ['arg']],
|
|
'with 2 arguments' => ['-arg1- _arg2_', '-%s- _%s_', ['arg1', 'arg2']],
|
|
'with an array of 1 elements' => ['_"arg1"_', '_%s_', [['arg1']]],
|
|
'with an array of 2 elements' => ['_"arg1" and "arg2"_', '_%s_', [['arg1', 'arg2']]],
|
|
'with an array of 3+ elements' => ['_"arg1", "arg2", and "arg3"_', '_%s_', [['arg1', 'arg2', 'arg3']]],
|
|
];
|
|
}
|
|
}
|