diff --git a/src/UnitOfWork.php b/src/UnitOfWork.php index 4ec0906843..26f17d27bb 100644 --- a/src/UnitOfWork.php +++ b/src/UnitOfWork.php @@ -2467,10 +2467,7 @@ public function createEntity(string $className, array $data, array &$hints = []) } else { $associatedId[$targetClass->fieldNames[$targetColumn]] = $joinColumnValue; } - } elseif ( - $targetClass->containsForeignIdentifier - && in_array($targetClass->getFieldForColumn($targetColumn), $targetClass->identifier, true) - ) { + } elseif (in_array($targetClass->getFieldForColumn($targetColumn), $targetClass->identifier, true)) { // the missing key is part of target's entity primary key $associatedId = []; break; diff --git a/tests/Tests/Models/CompositeKeyRelations/CustomerClass.php b/tests/Tests/Models/CompositeKeyRelations/CustomerClass.php new file mode 100644 index 0000000000..fb557f990d --- /dev/null +++ b/tests/Tests/Models/CompositeKeyRelations/CustomerClass.php @@ -0,0 +1,24 @@ +useModelSet('compositekeyrelations'); + + parent::setUp(); + } + + public function testFindEntityWithNotNullRelation(): void + { + $this->_em->getConnection()->insert('CustomerClass', [ + 'companyCode' => 'AA', + 'code' => 'CUST1', + 'name' => 'Customer 1', + ]); + + $this->_em->getConnection()->insert('InvoiceClass', [ + 'companyCode' => 'AA', + 'invoiceNumber' => 'INV1', + 'customerCode' => 'CUST1', + ]); + + $entity = $this->findEntity('AA', 'INV1'); + self::assertSame('AA', $entity->companyCode); + self::assertSame('INV1', $entity->invoiceNumber); + self::assertInstanceOf(CustomerClass::class, $entity->customer); + self::assertSame('Customer 1', $entity->customer->name); + } + + public function testFindEntityWithNullRelation(): void + { + $this->_em->getConnection()->insert('InvoiceClass', [ + 'companyCode' => 'BB', + 'invoiceNumber' => 'INV1', + ]); + + $entity = $this->findEntity('BB', 'INV1'); + self::assertSame('BB', $entity->companyCode); + self::assertSame('INV1', $entity->invoiceNumber); + self::assertNull($entity->customer); + } + + private function findEntity(string $companyCode, string $invoiceNumber): InvoiceClass + { + return $this->_em->find( + InvoiceClass::class, + ['companyCode' => $companyCode, 'invoiceNumber' => $invoiceNumber], + ); + } +} diff --git a/tests/Tests/OrmFunctionalTestCase.php b/tests/Tests/OrmFunctionalTestCase.php index cfb4f73b4d..edec9ca261 100644 --- a/tests/Tests/OrmFunctionalTestCase.php +++ b/tests/Tests/OrmFunctionalTestCase.php @@ -349,6 +349,10 @@ abstract class OrmFunctionalTestCase extends OrmTestCase SingleRootClass::class, SingleChildClass::class, ], + 'compositekeyrelations' => [ + Models\CompositeKeyRelations\InvoiceClass::class, + Models\CompositeKeyRelations\CustomerClass::class, + ], 'taxi' => [ PaidRide::class, Ride::class,