respect-validation/tests/feature/Validators/BeetwenTest.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

40 lines
1.4 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('Scenario #1', catchMessage(
fn() => v::between(1, 2)->assert(0),
fn(string $message) => expect($message)->toBe('0 must be between 1 and 2'),
));
test('Scenario #2', catchMessage(
fn() => v::not(v::between('yesterday', 'tomorrow'))->assert('today'),
fn(string $message) => expect($message)->toBe('"today" must not be between "yesterday" and "tomorrow"'),
));
test('Scenario #3', catchFullMessage(
fn() => v::between('a', 'c')->assert('d'),
fn(string $fullMessage) => expect($fullMessage)->toBe('- "d" must be between "a" and "c"'),
));
test('Scenario #4', catchFullMessage(
fn() => v::not(v::between(-INF, INF))->assert(0),
fn(string $fullMessage) => expect($fullMessage)->toBe('- 0 must not be between `-INF` and `INF`'),
));
test('Scenario #5', catchFullMessage(
fn() => v::not(v::between('a', 'b'))->assert('a'),
fn(string $fullMessage) => expect($fullMessage)->toBe('- "a" must not be between "a" and "b"'),
));
test('Scenario #6', catchFullMessage(
fn() => v::not(v::between(1, 42))->assert(41),
fn(string $fullMessage) => expect($fullMessage)->toBe('- 41 must not be between 1 and 42'),
));