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

30 lines
1 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::startsWith('b')->assert(['a', 'b']),
fn(string $message) => expect($message)->toBe('`["a", "b"]` must start with "b"'),
));
test('Scenario #2', catchMessage(
fn() => v::not(v::startsWith(1.1))->assert([1.1, 2.2]),
fn(string $message) => expect($message)->toBe('`[1.1, 2.2]` must not start with 1.1'),
));
test('Scenario #3', catchFullMessage(
fn() => v::startsWith('3.3')->assert([3.3, 4.4]),
fn(string $fullMessage) => expect($fullMessage)->toBe('- `[3.3, 4.4]` must start with "3.3"'),
));
test('Scenario #4', catchFullMessage(
fn() => v::not(v::startsWith('c'))->assert(['c', 'd']),
fn(string $fullMessage) => expect($fullMessage)->toBe('- `["c", "d"]` must not start with "c"'),
));