mirror of
https://github.com/danog/Valinor.git
synced 2025-01-10 14:48:20 +01:00
69ad3f4777
The cache implementation that was previously injected in the mapper builder must now be manually injected. This gives better control on when the cache should be enabled, especially depending on which environment the application is running. The library provides a cache implementation out of the box, which saves cache entries into the file system. It is also possible to use any PSR-16 compliant implementation, as long as it is capable of caching the entries handled by the library. ```php $cache = new \CuyZ\Valinor\Cache\FileSystemCache('path/to/cache-dir'); (new \CuyZ\Valinor\MapperBuilder()) ->withCache($cache) ->mapper() ->map(SomeClass::class, [/* … */]); ```
164 lines
5.6 KiB
PHP
164 lines
5.6 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace CuyZ\Valinor\Tests\Integration\Mapping\Object;
|
|
|
|
use CuyZ\Valinor\Mapper\MappingError;
|
|
use CuyZ\Valinor\MapperBuilder;
|
|
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 = (new 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 {
|
|
(new MapperBuilder())->mapper()->map(ListValues::class, [
|
|
'nonEmptyListOfStrings' => [],
|
|
]);
|
|
} catch (MappingError $exception) {
|
|
$error = $exception->node()->children()['nonEmptyListOfStrings']->messages()[0];
|
|
|
|
self::assertSame('1630678334', $error->code());
|
|
self::assertSame('Value array (empty) does not match type `non-empty-list<string>`.', (string)$error);
|
|
}
|
|
}
|
|
|
|
public function test_value_that_cannot_be_casted_throws_exception(): void
|
|
{
|
|
try {
|
|
(new 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 'foo' 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;
|
|
}
|
|
}
|