respect-validation/tests/feature/AssertWithPropertiesTest.php
Alexandre Gomes Gaigalas 33927e26d1
Fix isVisible() initial value bug in NestedListStringFormatter
The array_reduce in isVisible() used `true` as its initial value with
an `||` reducer, meaning it always returned `true` when siblings existed
regardless of their actual visibility. This caused unnecessary nesting
in full messages by showing single-child wrapper nodes that should have
been collapsed.

Replace array_reduce with a foreach loop starting from `false`, which
also enables early return on the first visible sibling.
2026-03-05 17:56:29 -03:00

49 lines
1.6 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', catchFullMessage(
fn() => v::named('the given data', v::init()
->property(
'mysql',
v::init()
->property('host', v::stringType())
->property('user', v::stringType())
->property('password', v::stringType())
->property('schema', v::stringType()),
)
->property(
'postgresql',
v::init()
->property('host', v::stringType())
->property('user', v::stringType())
->property('password', v::stringType())
->property('schema', v::stringType()),
))
->assert(json_decode((string) json_encode([
'mysql' => [
'host' => 42,
'user' => 'user',
'password' => 'password',
'schema' => 'schema',
],
'postgresql' => [
'host' => 'host',
'user' => 42,
'password' => 'password',
'schema' => 'schema',
],
]))),
fn(string $fullMessage) => expect($fullMessage)->toBe(<<<'FULL_MESSAGE'
- the given data must pass all the rules
- `.mysql.host` must be a string
- `.postgresql.user` must be a string
FULL_MESSAGE),
));