respect-validation/tests/feature/Validators/CallTest.php
Alexandre Gomes Gaigalas ec16b3d2df Refactor case sensitiveness support
This is a mid-size refactor that affects several validators.

Most prominently, the ones that had an `$identical` parameter
to deal with case sensitiveness.

This parameter was confusing, effectively making validators such
as `Contains` behave very differently for arrays versus strings.

In arrays, `$identical` meant "the same type", while it in strings
it meant "case sensitive".

That parameter was removed, and the default behavior is now to
always compare **case sensitive** and strict typing.

A document explaining how to combine other validators in order
to achieve case _insensitive_ comparisons was added.

Additionally, the `Call` validator was refactored back to be
suitable to take on the task of being a fast, quick composable
validator.

With the introduction of `Circuit`, we can shift the responsibility
of dealing with possible mismatches to the user. This kind of type
handling is demonstrated in how I refactored `Tld` to account for
the type mismatch without setting error handlers.
2026-01-30 17:11:13 +00:00

29 lines
1,011 B
PHP

<?php
/*
* SPDX-License-Identifier: MIT
* SPDX-FileCopyrightText: (c) Respect Project Contributors
* SPDX-FileContributor: Henrique Moody <henriquemoody@gmail.com>
*/
declare(strict_types=1);
test('Scenario #1', catchMessage(
fn() => v::call('trim', v::notSpaced())->assert(' two words '),
fn(string $message) => expect($message)->toBe('"two words" must not contain whitespaces'),
));
test('Scenario #2', catchMessage(
fn() => v::not(v::call('stripslashes', v::stringType()))->assert(' some\thing '),
fn(string $message) => expect($message)->toBe('" something " must not be a string'),
));
test('Scenario #3', catchFullMessage(
fn() => v::call('strval', v::intType())->assert(1234),
fn(string $fullMessage) => expect($fullMessage)->toBe('- "1234" must be an integer'),
));
test('Scenario #4', catchFullMessage(
fn() => v::not(v::call('is_float', v::boolType()))->assert(1.2),
fn(string $fullMessage) => expect($fullMessage)->toBe('- `true` must not be a boolean'),
));