1
0
mirror of synced 2025-02-03 13:59:27 +03:00
Luís Cobucci 1f53afa9cd
Make sure we're using the rootEntityName on all places
Otherwise we might end up with duplicated cache entries and weird
results (specially regarding associations).
2017-01-19 17:24:47 +01:00

129 lines
2.7 KiB
PHP

<?php
namespace Doctrine\Tests\ORM\Functional\Ticket;
use Doctrine\DBAL\Platforms\AbstractPlatform;
use Doctrine\DBAL\Types\StringType;
use Doctrine\DBAL\Types\Type;
use Doctrine\ORM\AbstractQuery;
use Doctrine\Tests\OrmFunctionalTestCase;
final class GH5562Test extends OrmFunctionalTestCase
{
protected function setUp()
{
$this->enableSecondLevelCache();
parent::setUp();
$this->_schemaTool->createSchema(
[
$this->_em->getClassMetadata(GH5562User::class),
$this->_em->getClassMetadata(GH5562Manager::class),
$this->_em->getClassMetadata(GH5562Merchant::class),
]
);
}
/**
* @group 5562
*/
public function testCacheShouldBeUpdatedWhenAssociationChanges()
{
$manager = new GH5562Manager();
$merchant = new GH5562Merchant();
$manager->username = 'username';
$manager->merchant = $merchant;
$merchant->manager = $manager;
$merchant->name = 'Merchant';
$this->_em->persist($merchant);
$this->_em->persist($manager);
$this->_em->flush();
$this->_em->clear();
$merchant = $this->_em->find(GH5562Merchant::class, $merchant->id);
$merchant->name = mt_rand();
$merchant->manager->username = 'usernameUPDATE';
$this->_em->flush();
$this->_em->clear();
$merchant = $this->_em->find(GH5562Merchant::class, $merchant->id);
self::assertEquals('usernameUPDATE', $merchant->manager->username);
}
}
/**
* @Entity
* @Cache(usage="NONSTRICT_READ_WRITE")
*/
class GH5562Merchant
{
/**
* @var integer
*
* @Id
* @Column(name="id", type="integer")
* @GeneratedValue(strategy="IDENTITY")
*/
public $id;
/**
* @var GH5562Manager
*
* @OneToOne(targetEntity=GH5562Manager::class, mappedBy="merchant")
* @Cache(usage="NONSTRICT_READ_WRITE")
*/
public $manager;
/**
* @var string
*
* @Column(name="name", type="string", length=255, nullable=false)
*/
public $name;
}
/**
* @Entity
* @InheritanceType("SINGLE_TABLE")
* @DiscriminatorMap({"MANAGER" = GH5562Manager::class})
*/
abstract class GH5562User
{
/**
* @var integer
*
* @Id
* @Column(name="id", type="integer")
* @GeneratedValue(strategy="IDENTITY")
*/
public $id;
}
/**
* @Entity
* @Cache(usage="NONSTRICT_READ_WRITE")
*/
class GH5562Manager extends GH5562User
{
/**
* @var string
*
* @Column
*/
public $username;
/**
* @var GH5562Merchant
*
* @OneToOne(targetEntity=GH5562Merchant::class, inversedBy="manager")
*/
public $merchant;
}