2013-02-14 02:42:13 +04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\ORM\Functional;
|
|
|
|
|
|
|
|
use Doctrine\Tests\Models\Cache\City;
|
|
|
|
use Doctrine\Tests\Models\Cache\State;
|
|
|
|
use Doctrine\Tests\Models\Cache\Travel;
|
|
|
|
use Doctrine\Tests\Models\Cache\Traveler;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @group DDC-2183
|
|
|
|
*/
|
|
|
|
class SecondLevelCacheManyToManyTest extends SecondLevelCacheAbstractTest
|
|
|
|
{
|
|
|
|
public function testShouldPutManyToManyCollectionOwningSideOnPersist()
|
|
|
|
{
|
|
|
|
$this->evictRegions();
|
|
|
|
|
|
|
|
$this->loadFixturesCountries();
|
|
|
|
$this->loadFixturesStates();
|
|
|
|
$this->loadFixturesCities();
|
|
|
|
$this->loadFixturesTraveler();
|
|
|
|
$this->loadFixturesTravels();
|
|
|
|
$this->_em->clear();
|
|
|
|
|
|
|
|
$this->assertTrue($this->cache->containsEntity(Travel::CLASSNAME, $this->travels[0]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(Travel::CLASSNAME, $this->travels[1]->getId()));
|
|
|
|
|
|
|
|
$this->assertTrue($this->cache->containsCollection(Travel::CLASSNAME, 'visitedCities', $this->travels[0]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsCollection(Travel::CLASSNAME, 'visitedCities', $this->travels[1]->getId()));
|
|
|
|
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[0]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[1]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[2]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[3]->getId()));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testPutAndLoadManyToManyRelation()
|
|
|
|
{
|
|
|
|
$this->evictRegions();
|
|
|
|
|
|
|
|
$this->loadFixturesCountries();
|
|
|
|
$this->loadFixturesStates();
|
|
|
|
$this->loadFixturesCities();
|
|
|
|
$this->loadFixturesTraveler();
|
|
|
|
$this->loadFixturesTravels();
|
|
|
|
|
|
|
|
$this->_em->clear();
|
2013-12-20 19:39:03 +04:00
|
|
|
$this->cache->evictEntityRegion(City::CLASSNAME);
|
|
|
|
$this->cache->evictEntityRegion(Travel::CLASSNAME);
|
|
|
|
$this->cache->evictCollectionRegion(Travel::CLASSNAME, 'visitedCities');
|
|
|
|
|
2013-02-14 02:42:13 +04:00
|
|
|
$this->secondLevelCacheLogger->clearStats();
|
|
|
|
|
|
|
|
$this->assertFalse($this->cache->containsEntity(Travel::CLASSNAME, $this->travels[0]->getId()));
|
|
|
|
$this->assertFalse($this->cache->containsEntity(Travel::CLASSNAME, $this->travels[1]->getId()));
|
|
|
|
|
|
|
|
$this->assertFalse($this->cache->containsCollection(Travel::CLASSNAME, 'visitedCities', $this->travels[0]->getId()));
|
|
|
|
$this->assertFalse($this->cache->containsCollection(Travel::CLASSNAME, 'visitedCities', $this->travels[1]->getId()));
|
|
|
|
|
|
|
|
$this->assertFalse($this->cache->containsEntity(City::CLASSNAME, $this->cities[0]->getId()));
|
|
|
|
$this->assertFalse($this->cache->containsEntity(City::CLASSNAME, $this->cities[1]->getId()));
|
|
|
|
$this->assertFalse($this->cache->containsEntity(City::CLASSNAME, $this->cities[2]->getId()));
|
|
|
|
$this->assertFalse($this->cache->containsEntity(City::CLASSNAME, $this->cities[3]->getId()));
|
|
|
|
|
|
|
|
$t1 = $this->_em->find(Travel::CLASSNAME, $this->travels[0]->getId());
|
|
|
|
$t2 = $this->_em->find(Travel::CLASSNAME, $this->travels[1]->getId());
|
|
|
|
|
|
|
|
$this->assertEquals(2, $this->secondLevelCacheLogger->getPutCount());
|
|
|
|
$this->assertEquals(2, $this->secondLevelCacheLogger->getMissCount());
|
|
|
|
$this->assertEquals(2, $this->secondLevelCacheLogger->getRegionPutCount($this->getEntityRegion(Travel::CLASSNAME)));
|
|
|
|
$this->assertEquals(2, $this->secondLevelCacheLogger->getRegionMissCount($this->getEntityRegion(Travel::CLASSNAME)));
|
|
|
|
|
|
|
|
//trigger lazy load
|
|
|
|
$this->assertCount(3, $t1->getVisitedCities());
|
|
|
|
$this->assertCount(2, $t2->getVisitedCities());
|
|
|
|
|
|
|
|
$this->assertEquals(4, $this->secondLevelCacheLogger->getPutCount());
|
|
|
|
$this->assertEquals(4, $this->secondLevelCacheLogger->getMissCount());
|
|
|
|
$this->assertEquals(2, $this->secondLevelCacheLogger->getRegionPutCount($this->getCollectionRegion(Travel::CLASSNAME, 'visitedCities')));
|
|
|
|
$this->assertEquals(2, $this->secondLevelCacheLogger->getRegionMissCount($this->getCollectionRegion(Travel::CLASSNAME, 'visitedCities')));
|
|
|
|
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t1->getVisitedCities()->get(0));
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t1->getVisitedCities()->get(1));
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t1->getVisitedCities()->get(2));
|
|
|
|
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t2->getVisitedCities()->get(0));
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t2->getVisitedCities()->get(1));
|
|
|
|
|
|
|
|
$this->assertTrue($this->cache->containsEntity(Travel::CLASSNAME, $this->travels[0]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(Travel::CLASSNAME, $this->travels[1]->getId()));
|
|
|
|
|
|
|
|
$this->assertTrue($this->cache->containsCollection(Travel::CLASSNAME, 'visitedCities', $this->travels[0]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsCollection(Travel::CLASSNAME, 'visitedCities', $this->travels[1]->getId()));
|
|
|
|
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[0]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[1]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[2]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[3]->getId()));
|
|
|
|
|
|
|
|
$this->_em->clear();
|
|
|
|
$this->secondLevelCacheLogger->clearStats();
|
|
|
|
|
|
|
|
$queryCount = $this->getCurrentQueryCount();
|
|
|
|
|
|
|
|
$t3 = $this->_em->find(Travel::CLASSNAME, $this->travels[0]->getId());
|
|
|
|
$t4 = $this->_em->find(Travel::CLASSNAME, $this->travels[1]->getId());
|
|
|
|
|
|
|
|
//trigger lazy load from cache
|
|
|
|
$this->assertCount(3, $t3->getVisitedCities());
|
|
|
|
$this->assertCount(2, $t4->getVisitedCities());
|
|
|
|
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t3->getVisitedCities()->get(0));
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t3->getVisitedCities()->get(1));
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t3->getVisitedCities()->get(2));
|
|
|
|
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t4->getVisitedCities()->get(0));
|
|
|
|
$this->assertInstanceOf(City::CLASSNAME, $t4->getVisitedCities()->get(1));
|
|
|
|
|
|
|
|
$this->assertEquals(4, $this->secondLevelCacheLogger->getHitCount());
|
|
|
|
$this->assertEquals(2, $this->secondLevelCacheLogger->getRegionHitCount($this->getEntityRegion(Travel::CLASSNAME)));
|
|
|
|
$this->assertEquals(2, $this->secondLevelCacheLogger->getRegionHitCount($this->getCollectionRegion(Travel::CLASSNAME, 'visitedCities')));
|
|
|
|
|
|
|
|
$this->assertNotSame($t1->getVisitedCities()->get(0), $t3->getVisitedCities()->get(0));
|
|
|
|
$this->assertEquals($t1->getVisitedCities()->get(0)->getId(), $t3->getVisitedCities()->get(0)->getId());
|
|
|
|
$this->assertEquals($t1->getVisitedCities()->get(0)->getName(), $t3->getVisitedCities()->get(0)->getName());
|
|
|
|
|
|
|
|
$this->assertNotSame($t1->getVisitedCities()->get(1), $t3->getVisitedCities()->get(1));
|
|
|
|
$this->assertEquals($t1->getVisitedCities()->get(1)->getId(), $t3->getVisitedCities()->get(1)->getId());
|
|
|
|
$this->assertEquals($t1->getVisitedCities()->get(1)->getName(), $t3->getVisitedCities()->get(1)->getName());
|
|
|
|
|
|
|
|
$this->assertNotSame($t1->getVisitedCities()->get(2), $t3->getVisitedCities()->get(2));
|
|
|
|
$this->assertEquals($t1->getVisitedCities()->get(2)->getId(), $t3->getVisitedCities()->get(2)->getId());
|
|
|
|
$this->assertEquals($t1->getVisitedCities()->get(2)->getName(), $t3->getVisitedCities()->get(2)->getName());
|
|
|
|
|
|
|
|
$this->assertNotSame($t2->getVisitedCities()->get(0), $t4->getVisitedCities()->get(0));
|
|
|
|
$this->assertEquals($t2->getVisitedCities()->get(0)->getId(), $t4->getVisitedCities()->get(0)->getId());
|
|
|
|
$this->assertEquals($t2->getVisitedCities()->get(0)->getName(), $t4->getVisitedCities()->get(0)->getName());
|
|
|
|
|
|
|
|
$this->assertNotSame($t2->getVisitedCities()->get(1), $t4->getVisitedCities()->get(1));
|
|
|
|
$this->assertEquals($t2->getVisitedCities()->get(1)->getId(), $t4->getVisitedCities()->get(1)->getId());
|
|
|
|
$this->assertEquals($t2->getVisitedCities()->get(1)->getName(), $t4->getVisitedCities()->get(1)->getName());
|
|
|
|
|
|
|
|
$this->assertEquals(4, $this->secondLevelCacheLogger->getHitCount());
|
|
|
|
$this->assertEquals($queryCount, $this->getCurrentQueryCount());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testStoreManyToManyAssociationWhitCascade()
|
|
|
|
{
|
|
|
|
$this->evictRegions();
|
|
|
|
|
|
|
|
$this->loadFixturesCountries();
|
|
|
|
$this->loadFixturesStates();
|
|
|
|
$this->loadFixturesCities();
|
|
|
|
|
|
|
|
$this->cache->evictEntityRegion(City::CLASSNAME);
|
|
|
|
$this->cache->evictEntityRegion(Traveler::CLASSNAME);
|
|
|
|
$this->cache->evictEntityRegion(Travel::CLASSNAME);
|
|
|
|
$this->cache->evictCollectionRegion(State::CLASSNAME, 'cities');
|
|
|
|
$this->cache->evictCollectionRegion(Traveler::CLASSNAME, 'travels');
|
|
|
|
|
|
|
|
$traveler = new Traveler('Doctrine Bot');
|
|
|
|
$travel = new Travel($traveler);
|
|
|
|
|
|
|
|
$travel->addVisitedCity($this->cities[0]);
|
|
|
|
$travel->addVisitedCity($this->cities[1]);
|
|
|
|
$travel->addVisitedCity($this->cities[3]);
|
|
|
|
|
|
|
|
$this->_em->persist($traveler);
|
|
|
|
$this->_em->persist($travel);
|
|
|
|
$this->_em->flush();
|
|
|
|
$this->_em->clear();
|
|
|
|
|
|
|
|
$this->assertTrue($this->cache->containsEntity(Traveler::CLASSNAME, $travel->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(Traveler::CLASSNAME, $traveler->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[0]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[1]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsEntity(City::CLASSNAME, $this->cities[3]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsCollection(Travel::CLASSNAME, 'visitedCities', $travel->getId()));
|
|
|
|
|
|
|
|
$queryCount1 = $this->getCurrentQueryCount();
|
|
|
|
$t1 = $this->_em->find(Travel::CLASSNAME, $travel->getId());
|
|
|
|
|
|
|
|
$this->assertInstanceOf(Travel::CLASSNAME, $t1);
|
|
|
|
$this->assertCount(3, $t1->getVisitedCities());
|
|
|
|
$this->assertEquals($queryCount1, $this->getCurrentQueryCount());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \Doctrine\ORM\Cache\CacheException
|
|
|
|
* @expectedExceptionMessage Cannot update a readonly collection "Doctrine\Tests\Models\Cache\Travel#visitedCities
|
|
|
|
*/
|
|
|
|
public function testReadOnlyCollection()
|
|
|
|
{
|
|
|
|
$this->evictRegions();
|
|
|
|
|
|
|
|
$this->loadFixturesCountries();
|
|
|
|
$this->loadFixturesStates();
|
|
|
|
$this->loadFixturesCities();
|
|
|
|
$this->loadFixturesTraveler();
|
|
|
|
$this->loadFixturesTravels();
|
|
|
|
|
|
|
|
$this->_em->clear();
|
|
|
|
|
|
|
|
$this->assertTrue($this->cache->containsEntity(Travel::CLASSNAME, $this->travels[0]->getId()));
|
|
|
|
$this->assertTrue($this->cache->containsCollection(Travel::CLASSNAME, 'visitedCities', $this->travels[0]->getId()));
|
|
|
|
|
|
|
|
$travel = $this->_em->find(Travel::CLASSNAME, $this->travels[0]->getId());
|
|
|
|
|
|
|
|
$this->assertCount(3, $travel->getVisitedCities());
|
|
|
|
|
|
|
|
$travel->getVisitedCities()->remove(0);
|
|
|
|
|
|
|
|
$this->_em->persist($travel);
|
|
|
|
$this->_em->flush();
|
|
|
|
}
|
|
|
|
}
|