Merge branch 'DDC-1964'
This commit is contained in:
commit
e8d3fc73ff
@ -448,6 +448,7 @@ class ObjectHydrator extends AbstractHydrator
|
||||
$this->_resultPointers[$dqlAlias] = $element;
|
||||
} else {
|
||||
$this->_uow->setOriginalEntityProperty($oid, $relationField, null);
|
||||
$reflField->setValue($parentObject, null);
|
||||
}
|
||||
// else leave $reflFieldValue null for single-valued associations
|
||||
} else {
|
||||
|
@ -21,6 +21,7 @@ class OneToOneEagerLoadingTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
||||
$this->_em->getClassMetadata('Doctrine\Tests\ORM\Functional\TrainDriver'),
|
||||
$this->_em->getClassMetadata('Doctrine\Tests\ORM\Functional\TrainOwner'),
|
||||
$this->_em->getClassMetadata('Doctrine\Tests\ORM\Functional\Waggon'),
|
||||
$this->_em->getClassMetadata('Doctrine\Tests\ORM\Functional\TrainOrder'),
|
||||
));
|
||||
} catch(\Exception $e) {}
|
||||
}
|
||||
@ -181,6 +182,24 @@ class OneToOneEagerLoadingTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
||||
$this->_sqlLoggerStack->queries[$this->_sqlLoggerStack->currentQuery]['sql']
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @group DDC-1946
|
||||
*/
|
||||
public function testEagerLoadingDoesNotBreakRefresh()
|
||||
{
|
||||
$train = new Train(new TrainOwner('Johannes'));
|
||||
$order = new TrainOrder($train);
|
||||
$this->_em->persist($train);
|
||||
$this->_em->persist($order);
|
||||
$this->_em->flush();
|
||||
|
||||
$this->_em->getConnection()->exec("UPDATE TrainOrder SET train_id = NULL");
|
||||
|
||||
$this->assertSame($train, $order->train);
|
||||
$this->_em->refresh($order);
|
||||
$this->assertTrue($order->train === null, "Train reference was not refreshed to NULL.");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@ -305,3 +324,20 @@ class Waggon
|
||||
$this->train = $train;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @Entity
|
||||
*/
|
||||
class TrainOrder
|
||||
{
|
||||
/** @id @generatedValue @column(type="integer") */
|
||||
public $id;
|
||||
|
||||
/** @OneToOne(targetEntity = "Train", fetch = "EAGER") */
|
||||
public $train;
|
||||
|
||||
public function __construct(Train $train)
|
||||
{
|
||||
$this->train = $train;
|
||||
}
|
||||
}
|
||||
|
@ -5,6 +5,9 @@ use Doctrine\ORM\Query;
|
||||
|
||||
require_once __DIR__ . '/../../../TestInit.php';
|
||||
|
||||
/**
|
||||
* @group DDC-371
|
||||
*/
|
||||
class DDC371Test extends \Doctrine\Tests\OrmFunctionalTestCase
|
||||
{
|
||||
protected function setUp()
|
||||
|
Loading…
x
Reference in New Issue
Block a user