mirror of
https://github.com/Respect/Validation.git
synced 2026-03-14 22:35:45 +01:00
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.
49 lines
1.6 KiB
PHP
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),
|
|
));
|