respect-validation/tests/feature/Issues/Issue179Test.php
Henrique Moody 7c681fec66
Fix SPDX headers in all files
I ran the `bin/console spdx --fix` with different strategies for
different files. For most of the core classes, since they've been
drastically rebuilt, I've run it with the `git-blame` strategy, for for
the `src/Validators`, in which the API changed completely but the logic
remains the same, I use the `git-log` strategy.
2026-02-03 15:23:23 +01:00

42 lines
1.3 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>
*/
declare(strict_types=1);
test('https://github.com/Respect/Validation/issues/179', catchAll(
function (): void {
$config = [
'host' => 1,
'password' => 'my_password',
'schema' => 'my_schema',
];
$validator = v::named(
'Settings',
v::arrayType()
->key('host', v::stringType())
->key('user', v::stringType())
->key('password', v::stringType())
->key('schema', v::stringType()),
);
$validator->assert($config);
},
fn(string $message, string $fullMessage, array $messages) => expect()
->and($message)->toBe('`.host` (<- Settings) must be a string')
->and($fullMessage)->toBe(<<<'FULL_MESSAGE'
- Settings must pass the rules
- `.host` must be a string
- `.user` must be present
FULL_MESSAGE)
->and($messages)->toBe([
'__root__' => 'Settings must pass the rules',
'host' => '`.host` must be a string',
'user' => '`.user` must be present',
]),
));