diff --git a/src/Transformer/NullableTransformerFactory.php b/src/Transformer/NullableTransformerFactory.php index 13450c1..bf48a57 100644 --- a/src/Transformer/NullableTransformerFactory.php +++ b/src/Transformer/NullableTransformerFactory.php @@ -21,6 +21,10 @@ final class NullableTransformerFactory implements TransformerFactoryInterface, P public function getTransformer(TypesMatching $types, SourcePropertyMetadata $source, TargetPropertyMetadata $target, MapperMetadata $mapperMetadata): ?TransformerInterface { + if (null !== $target->parameterInConstructor) { + return null; + } + $sourceType = $types->getSourceUniqueType(); if (null === $sourceType) { diff --git a/tests/AutoMapperTest.php b/tests/AutoMapperTest.php index 565cb8d..2b30c20 100644 --- a/tests/AutoMapperTest.php +++ b/tests/AutoMapperTest.php @@ -525,6 +525,15 @@ public function testConstructorForcedException(): void $this->autoMapper->map($data, ConstructorWithDefaultValues::class); } + public function testConstructorWithDefaultFromStdClass(): void + { + $data = (object) ['baz' => 'baz']; + /** @var ConstructorWithDefaultValues $object */ + $object = $this->autoMapper->map($data, ConstructorWithDefaultValues::class); + + self::assertInstanceOf(ConstructorWithDefaultValues::class, $object); + } + public function testConstructorWithDefault(): void { $user = new Fixtures\UserDTONoAge();