From a73a1e8437fcf03a7a333df36d38bd01ed9d58ee Mon Sep 17 00:00:00 2001 From: Benjamin Eberlei Date: Sat, 25 Jun 2011 14:38:44 +0200 Subject: [PATCH] DDC-1226, DDC-1228 - Bugfix with refereshing proxy references not setting the originalEntityData. --- lib/Doctrine/ORM/UnitOfWork.php | 5 +- .../ORM/Functional/Ticket/DDC1228Test.php | 136 ++++++++++++++++++ 2 files changed, 140 insertions(+), 1 deletion(-) create mode 100644 tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1228Test.php diff --git a/lib/Doctrine/ORM/UnitOfWork.php b/lib/Doctrine/ORM/UnitOfWork.php index 4b4be9e31..3d46303ea 100644 --- a/lib/Doctrine/ORM/UnitOfWork.php +++ b/lib/Doctrine/ORM/UnitOfWork.php @@ -1884,13 +1884,16 @@ class UnitOfWork implements PropertyChangedListener if ($entity instanceof Proxy && ! $entity->__isInitialized__) { $entity->__isInitialized__ = true; $overrideLocalValues = true; - $this->originalEntityData[$oid] = $data; if ($entity instanceof NotifyPropertyChanged) { $entity->addPropertyChangedListener($this); } } else { $overrideLocalValues = isset($hints[Query::HINT_REFRESH]); } + + if ($overrideLocalValues) { + $this->originalEntityData[$oid] = $data; + } } else { $entity = $class->newInstance(); $oid = spl_object_hash($entity); diff --git a/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1228Test.php b/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1228Test.php new file mode 100644 index 000000000..34aef78cf --- /dev/null +++ b/tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1228Test.php @@ -0,0 +1,136 @@ +_schemaTool->createSchema(array( + $this->_em->getClassMetadata(__NAMESPACE__ . '\\DDC1228User'), + $this->_em->getClassMetadata(__NAMESPACE__ . '\\DDC1228Profile'), + )); + } catch(\PDOException $e) { + + } + } + + public function testOneToOnePersist() + { + $user = new DDC1228User; + $profile = new DDC1228Profile(); + $profile->name = "Foo"; + $user->profile = $profile; + + $this->_em->persist($user); + $this->_em->persist($profile); + $this->_em->flush(); + $this->_em->clear(); + + $user = $this->_em->find(__NAMESPACE__ . '\\DDC1228User', $user->id); + + $this->assertFalse($user->getProfile()->__isInitialized__, "Proxy is not initialized"); + $user->getProfile()->setName("Bar"); + $this->assertTrue($user->getProfile()->__isInitialized__, "Proxy is not initialized"); + + $this->assertEquals("Bar", $user->getProfile()->getName()); + $this->assertEquals(array("id" => 1, "name" => "Foo"), $this->_em->getUnitOfWork()->getOriginalEntityData($user->getProfile())); + + $this->_em->flush(); + $this->_em->clear(); + + $user = $this->_em->find(__NAMESPACE__ . '\\DDC1228User', $user->id); + $this->assertEquals("Bar", $user->getProfile()->getName()); + } + + public function testRefresh() + { + $user = new DDC1228User; + $profile = new DDC1228Profile(); + $profile->name = "Foo"; + $user->profile = $profile; + + $this->_em->persist($user); + $this->_em->persist($profile); + $this->_em->flush(); + $this->_em->clear(); + + $user = $this->_em->getReference(__NAMESPACE__ . '\\DDC1228User', $user->id); + + $this->_em->refresh($user); + $user->name = "Baz"; + $this->_em->flush(); + $this->_em->clear(); + + $user = $this->_em->find(__NAMESPACE__ . '\\DDC1228User', $user->id); + $this->assertEquals("Baz", $user->name); + } +} + +/** + * @Entity + */ +class DDC1228User +{ + /** + * @Id @Column(type="integer") @GeneratedValue + * @var int + */ + public $id; + + /** + * @column(type="string") + * @var string + */ + public $name = ''; + + /** + * @OneToOne(targetEntity="DDC1228Profile") + * @var Profile + */ + public $profile; + + public function getProfile() + { + return $this->profile; + } +} + +/** + * @Entity + */ +class DDC1228Profile +{ + /** + * @Id @Column(type="integer") @GeneratedValue + * @var int + */ + public $id; + + /** + * @column(type="string") + * @var string + */ + public $name; + + public function getName() + { + return $this->name; + } + + public function setName($name) + { + $this->name = $name; + } +} \ No newline at end of file