respect-validation/tests/Pest.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

117 lines
3.2 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);
use Respect\Validation\Exceptions\ValidationException;
function catchAll(Closure $try, Closure $catch): Closure
{
return function () use ($try, $catch): void {
try {
$try->call($this);
test()->expectException(ValidationException::class);
} catch (ValidationException $e) {
$catch->call($this, $e->getMessage(), $e->getFullMessage(), $e->getMessages());
}
};
}
function catchMessage(Closure $try, Closure $catch): Closure
{
return function () use ($try, $catch): void {
try {
$try->call($this);
test()->expectException(ValidationException::class);
} catch (ValidationException $e) {
$catch->call($this, $e->getMessage());
}
};
}
function catchFullMessage(Closure $try, Closure $catch): Closure
{
return function () use ($try, $catch): void {
try {
$try->call($this);
test()->expectException(ValidationException::class);
} catch (ValidationException $e) {
$catch->call($this, $e->getFullMessage());
}
};
}
function catchMessages(Closure $try, Closure $catch): Closure
{
return function () use ($try, $catch): void {
try {
$try->call($this);
test()->expectException(ValidationException::class);
} catch (ValidationException $e) {
$catch->call($this, $e->getMessages());
}
};
}
function expectDeprecation(Closure $callback, string $error): Closure
{
return function () use ($callback, $error): void {
$lastError = null;
set_error_handler(static function (int $errno, string $errstr) use (&$lastError): bool {
if ($errno !== E_USER_DEPRECATED) {
return false;
}
$lastError = $errstr;
return true;
});
try {
$callback->call($this);
} catch (Throwable $throwable) {
restore_error_handler();
throw $throwable;
}
restore_error_handler();
expect($lastError)->toBe($error);
};
}
function expectMessageAndDeprecation(Closure $callback, string $message, string $error): Closure
{
return function () use ($callback, $message, $error): void {
$lastError = null;
set_error_handler(static function (int $errno, string $errstr) use (&$lastError): bool {
if ($errno !== E_USER_DEPRECATED) {
return false;
}
$lastError = $errstr;
return true;
});
try {
$callback->call($this);
test()->expectException(ValidationException::class);
} catch (ValidationException $e) {
expect($e->getMessage())->toBe($message, 'Validation message does not match');
} catch (Throwable $throwable) {
restore_error_handler();
throw $throwable;
}
restore_error_handler();
expect($lastError)->toBe($error);
};
}