mirror of
https://github.com/danog/Valinor.git
synced 2025-01-10 14:48:20 +01:00
a805ba0442
A new class `NodeMessage` is used to wrap messages added to a node during the mapping. This class will allow further features by giving access to useful data related to the bound node. BREAKING CHANGE: as of now every message is wrapped into a `NodeMessage` it is therefore not possible to check whether the message is an instance of `Throwable` — a new method `$message->isError()` is now to be used for such cases.
163 lines
5.5 KiB
PHP
163 lines
5.5 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace CuyZ\Valinor\Tests\Integration\Mapping\Object;
|
|
|
|
use CuyZ\Valinor\Mapper\MappingError;
|
|
use CuyZ\Valinor\Tests\Integration\IntegrationTest;
|
|
use CuyZ\Valinor\Tests\Integration\Mapping\Fixture\SimpleObject;
|
|
use CuyZ\Valinor\Tests\Integration\Mapping\Fixture\SimpleObject as SimpleObjectAlias;
|
|
|
|
use function array_values;
|
|
|
|
final class ListValuesMappingTest extends IntegrationTest
|
|
{
|
|
public function test_values_are_mapped_properly(): void
|
|
{
|
|
$source = [
|
|
'booleans' => [true, false, true],
|
|
'floats' => [42.404, 404.42],
|
|
'integers' => [42, 404, 1337],
|
|
'strings' => ['foo', 'bar', 'baz'],
|
|
'objects' => [
|
|
['value' => 'foo'],
|
|
['value' => 'bar'],
|
|
['value' => 'baz'],
|
|
],
|
|
'objectsWithAlias' => [
|
|
['value' => 'foo'],
|
|
['value' => 'bar'],
|
|
['value' => 'baz'],
|
|
],
|
|
'nonEmptyListOfStrings' => ['foo', 'bar', 'baz'],
|
|
'listOfStringsWithKeys' => [
|
|
'foo' => 'foo',
|
|
'bar' => 'bar',
|
|
'baz' => 'baz',
|
|
],
|
|
'nonEmptyListOfStringsWithKeys' => [
|
|
'foo' => 'foo',
|
|
'bar' => 'bar',
|
|
'baz' => 'baz',
|
|
],
|
|
];
|
|
|
|
foreach ([ListValues::class, ListValuesWithConstructor::class] as $class) {
|
|
try {
|
|
$result = $this->mapperBuilder->mapper()->map($class, $source);
|
|
} catch (MappingError $error) {
|
|
$this->mappingFail($error);
|
|
}
|
|
|
|
self::assertSame($source['booleans'], $result->booleans);
|
|
self::assertSame($source['floats'], $result->floats);
|
|
self::assertSame($source['integers'], $result->integers);
|
|
self::assertSame($source['strings'], $result->strings);
|
|
self::assertSame('foo', $result->objects[0]->value);
|
|
self::assertSame('bar', $result->objects[1]->value);
|
|
self::assertSame('baz', $result->objects[2]->value);
|
|
self::assertSame('foo', $result->objectsWithAlias[0]->value);
|
|
self::assertSame('bar', $result->objectsWithAlias[1]->value);
|
|
self::assertSame('baz', $result->objectsWithAlias[2]->value);
|
|
self::assertSame($source['nonEmptyListOfStrings'], $result->nonEmptyListOfStrings);
|
|
self::assertSame(array_values($source['listOfStringsWithKeys']), $result->listOfStringsWithKeys);
|
|
self::assertSame(array_values($source['nonEmptyListOfStringsWithKeys']), $result->nonEmptyListOfStringsWithKeys);
|
|
}
|
|
}
|
|
|
|
public function test_empty_list_in_non_empty_list_throws_exception(): void
|
|
{
|
|
try {
|
|
$this->mapperBuilder->mapper()->map(ListValues::class, [
|
|
'nonEmptyListOfStrings' => [],
|
|
]);
|
|
} catch (MappingError $exception) {
|
|
$error = $exception->node()->children()['nonEmptyListOfStrings']->messages()[0];
|
|
|
|
self::assertSame('1630678334', $error->code());
|
|
self::assertSame('Empty array is not accepted by `non-empty-list<string>`.', (string)$error);
|
|
}
|
|
}
|
|
|
|
public function test_value_that_cannot_be_casted_throws_exception(): void
|
|
{
|
|
try {
|
|
$this->mapperBuilder->mapper()->map(ListValues::class, [
|
|
'integers' => ['foo'],
|
|
]);
|
|
} catch (MappingError $exception) {
|
|
$error = $exception->node()->children()['integers']->children()['0']->messages()[0];
|
|
|
|
self::assertSame('1618736242', $error->code());
|
|
self::assertSame('Cannot cast value of type `string` to `int`.', (string)$error);
|
|
}
|
|
}
|
|
}
|
|
|
|
class ListValues
|
|
{
|
|
/** @var list<bool> */
|
|
public array $booleans;
|
|
|
|
/** @var list<float> */
|
|
public array $floats;
|
|
|
|
/** @var list<int> */
|
|
public array $integers;
|
|
|
|
/** @var list<string> */
|
|
public array $strings;
|
|
|
|
/** @var list<SimpleObject> */
|
|
public array $objects;
|
|
|
|
/** @var list<SimpleObjectAlias> */
|
|
public array $objectsWithAlias;
|
|
|
|
/** @var non-empty-list<string> */
|
|
public array $nonEmptyListOfStrings = ['foo'];
|
|
|
|
/** @var list<string> */
|
|
public array $listOfStringsWithKeys;
|
|
|
|
/** @var non-empty-list<string> */
|
|
public array $nonEmptyListOfStringsWithKeys;
|
|
}
|
|
|
|
class ListValuesWithConstructor extends ListValues
|
|
{
|
|
/**
|
|
* @param list<bool> $booleans
|
|
* @param list<float> $floats
|
|
* @param list<int> $integers
|
|
* @param list<string> $strings
|
|
* @param list<SimpleObject> $objects
|
|
* @param list<SimpleObjectAlias> $objectsWithAlias
|
|
* @param non-empty-list<string> $nonEmptyListOfStrings
|
|
* @param list<string> $listOfStringsWithKeys
|
|
* @param non-empty-list<string> $nonEmptyListOfStringsWithKeys
|
|
*/
|
|
public function __construct(
|
|
array $booleans,
|
|
array $floats,
|
|
array $integers,
|
|
array $strings,
|
|
array $objects,
|
|
array $objectsWithAlias,
|
|
array $nonEmptyListOfStrings,
|
|
array $listOfStringsWithKeys,
|
|
array $nonEmptyListOfStringsWithKeys
|
|
) {
|
|
$this->booleans = $booleans;
|
|
$this->floats = $floats;
|
|
$this->integers = $integers;
|
|
$this->strings = $strings;
|
|
$this->objects = $objects;
|
|
$this->objectsWithAlias = $objectsWithAlias;
|
|
$this->nonEmptyListOfStrings = $nonEmptyListOfStrings;
|
|
$this->listOfStringsWithKeys = $listOfStringsWithKeys;
|
|
$this->nonEmptyListOfStringsWithKeys = $nonEmptyListOfStringsWithKeys;
|
|
}
|
|
}
|