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

Merge pull request #1030 from doctrine/hotfix/DDC-3123-extra-updates-cleanup

DDC-3123 extra updates cleanup
This commit is contained in:
Steve Müller 2014-05-15 01:07:34 +02:00
commit c16de21172
2 changed files with 50 additions and 0 deletions

View File

@ -483,6 +483,8 @@ class UnitOfWork implements PropertyChangedListener
$this->entityChangeSets[$oid] = $changeset;
$this->getEntityPersister(get_class($entity))->update($entity);
}
$this->extraUpdates = array();
}
/**

View File

@ -0,0 +1,48 @@
<?php
namespace Doctrine\Tests\ORM\Functional\Ticket;
use Doctrine\ORM\Events;
use Doctrine\Tests\Models\CMS\CmsUser;
/**
* @group DDC-3123
*/
class DDC3123Test extends \Doctrine\Tests\OrmFunctionalTestCase
{
protected function setUp()
{
$this->useModelSet('cms');
parent::setUp();
}
public function testIssue()
{
$test = $this;
$user = new CmsUser();
$uow = $this->_em->getUnitOfWork();
$user->name = 'Marco';
$user->username = 'ocramius';
$this->_em->persist($user);
$uow->scheduleExtraUpdate($user, array('name' => 'changed name'));
$listener = $this->getMock('stdClass', array('postFlush'));
$listener
->expects($this->once())
->method('postFlush')
->will($this->returnCallback(function () use ($uow, $test) {
$extraUpdatesReflection = new \ReflectionProperty($uow, 'extraUpdates');
$extraUpdatesReflection->setAccessible(true);
$test->assertEmpty($extraUpdatesReflection->getValue($uow));
}));
$this->_em->getEventManager()->addEventListener(Events::postFlush, $listener);
$this->_em->flush();
}
}