respect-validation/tests/feature/Validators/KeyExistsTest.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.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>
*/
declare(strict_types=1);
test('Default mode', catchAll(
fn() => v::keyExists('foo')->assert(['bar' => 'baz']),
fn(string $message, string $fullMessage, array $messages) => expect()
->and($message)->toBe('`.foo` must be present')
->and($fullMessage)->toBe('- `.foo` must be present')
->and($messages)->toBe(['foo' => '`.foo` must be present']),
));
test('Inverted mode', catchAll(
fn() => v::not(v::keyExists('foo'))->assert(['foo' => 'baz']),
fn(string $message, string $fullMessage, array $messages) => expect()
->and($message)->toBe('`.foo` must not be present')
->and($fullMessage)->toBe('- `.foo` must not be present')
->and($messages)->toBe(['foo' => '`.foo` must not be present']),
));
test('Custom name', catchAll(
fn() => v::named('Custom name', v::keyExists('foo'))->assert(['bar' => 'baz']),
fn(string $message, string $fullMessage, array $messages) => expect()
->and($message)->toBe('`.foo` (<- Custom name) must be present')
->and($fullMessage)->toBe('- `.foo` (<- Custom name) must be present')
->and($messages)->toBe(['foo' => '`.foo` (<- Custom name) must be present']),
));
test('Custom template', catchAll(
fn() => v::keyExists('foo')->assert(['bar' => 'baz'], 'Custom template for {{subject}}'),
fn(string $message, string $fullMessage, array $messages) => expect()
->and($message)->toBe('Custom template for `.foo`')
->and($fullMessage)->toBe('- Custom template for `.foo`')
->and($messages)->toBe(['foo' => 'Custom template for `.foo`']),
));