respect-validation/tests/feature/Validators/InstanceTest.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.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::instance(DateTime::class)->assert(''),
fn(string $message) => expect($message)->toBe('"" must be an instance of `DateTime`'),
));
test('Scenario #2', catchMessage(
fn() => v::not(v::instance(Traversable::class))->assert(new ArrayObject()),
fn(string $message) => expect($message)->toBe('`ArrayObject { getArrayCopy() => [] }` must not be an instance of `Traversable`'),
));
test('Scenario #3', catchFullMessage(
fn() => v::instance(ArrayIterator::class)->assert(new stdClass()),
fn(string $fullMessage) => expect($fullMessage)->toBe('- `stdClass {}` must be an instance of `ArrayIterator`'),
));
test('Scenario #4', catchFullMessage(
fn() => v::not(v::instance(stdClass::class))->assert(new stdClass()),
fn(string $fullMessage) => expect($fullMessage)->toBe('- `stdClass {}` must not be an instance of `stdClass`'),
));