1
0
mirror of synced 2025-01-18 14:31:40 +03:00

DDC-1519 - Fix bug in merging of entities that contain foreign identifiers

This commit is contained in:
Benjamin Eberlei 2011-12-15 20:49:25 +01:00
parent 41a3d90a57
commit e8a47b3921
3 changed files with 32 additions and 3 deletions

View File

@ -117,7 +117,7 @@ class EntityRepository implements ObjectRepository
} }
$sortedId[$identifier] = $id[$identifier]; $sortedId[$identifier] = $id[$identifier];
} }
// Check identity map first // Check identity map first
if ($entity = $this->_em->getUnitOfWork()->tryGetById($sortedId, $this->_class->rootEntityName)) { if ($entity = $this->_em->getUnitOfWork()->tryGetById($sortedId, $this->_class->rootEntityName)) {
if ( ! ($entity instanceof $this->_class->name)) { if ( ! ($entity instanceof $this->_class->name)) {

View File

@ -1647,7 +1647,20 @@ class UnitOfWork implements PropertyChangedListener
$this->persistNew($class, $managedCopy); $this->persistNew($class, $managedCopy);
} else { } else {
$managedCopy = $this->tryGetById($id, $class->rootEntityName); $flatId = $id;
if ($class->containsForeignIdentifier) {
// convert foreign identifiers into scalar foreign key
// values to avoid object to string conversion failures.
foreach ($id as $idField => $idValue) {
if (isset($class->associationMappings[$idField])) {
$targetClassMetadata = $this->em->getClassMetadata($class->associationMappings[$idField]['targetEntity']);
$associatedId = $this->getEntityIdentifier($idValue);
$flatId[$idField] = $associatedId[$targetClassMetadata->identifier[0]];
}
}
}
$managedCopy = $this->tryGetById($flatId, $class->rootEntityName);
if ($managedCopy) { if ($managedCopy) {
// We have the entity in-memory already, just make sure its not removed. // We have the entity in-memory already, just make sure its not removed.
@ -1657,7 +1670,7 @@ class UnitOfWork implements PropertyChangedListener
} }
} else { } else {
// We need to fetch the managed copy in order to merge. // We need to fetch the managed copy in order to merge.
$managedCopy = $this->em->find($class->name, $id); $managedCopy = $this->em->find($class->name, $flatId);
} }
if ($managedCopy === null) { if ($managedCopy === null) {

View File

@ -417,4 +417,20 @@ class DDC117Test extends \Doctrine\Tests\OrmFunctionalTestCase
return $this->_em->find(get_class($editor), $editor->id); return $this->_em->find(get_class($editor), $editor->id);
} }
/**
* @group DDC-1519
*/
public function testMergeForeignKeyIdentifierEntity()
{
$idCriteria = array('source' => $this->article1->id(), 'target' => $this->article2->id());
$refRep = $this->_em->find("Doctrine\Tests\Models\DDC117\DDC117Reference", $idCriteria);
$this->_em->detach($refRep);
$refRep = $this->_em->merge($refRep);
$this->assertEquals($this->article1->id(), $refRep->source()->id());
$this->assertEquals($this->article2->id(), $refRep->target()->id());
}
} }