public function testMultipleCaches() { $coolRegion = 'my_collection_region'; $entityRegion = 'my_entity_region'; $queryRegion = 'my_query_region'; $coolKey = new CollectionCacheKey(State::CLASSNAME, 'cities', array('id' => 1)); $entityKey = new EntityCacheKey(State::CLASSNAME, array('id' => 1)); $queryKey = new QueryCacheKey('my_query_hash'); $this->logger->queryCacheHit($queryRegion, $queryKey); $this->logger->queryCachePut($queryRegion, $queryKey); $this->logger->queryCacheMiss($queryRegion, $queryKey); $this->logger->entityCacheHit($entityRegion, $entityKey); $this->logger->entityCachePut($entityRegion, $entityKey); $this->logger->entityCacheMiss($entityRegion, $entityKey); $this->logger->collectionCacheHit($coolRegion, $coolKey); $this->logger->collectionCachePut($coolRegion, $coolKey); $this->logger->collectionCacheMiss($coolRegion, $coolKey); $this->assertEquals(3, $this->logger->getHitCount()); $this->assertEquals(3, $this->logger->getPutCount()); $this->assertEquals(3, $this->logger->getMissCount()); $this->assertEquals(1, $this->logger->getRegionHitCount($queryRegion)); $this->assertEquals(1, $this->logger->getRegionPutCount($queryRegion)); $this->assertEquals(1, $this->logger->getRegionMissCount($queryRegion)); $this->assertEquals(1, $this->logger->getRegionHitCount($coolRegion)); $this->assertEquals(1, $this->logger->getRegionPutCount($coolRegion)); $this->assertEquals(1, $this->logger->getRegionMissCount($coolRegion)); $this->assertEquals(1, $this->logger->getRegionHitCount($entityRegion)); $this->assertEquals(1, $this->logger->getRegionPutCount($entityRegion)); $this->assertEquals(1, $this->logger->getRegionMissCount($entityRegion)); $miss = $this->logger->getRegionsMiss(); $hit = $this->logger->getRegionsHit(); $put = $this->logger->getRegionsPut(); $this->assertArrayHasKey($coolRegion, $miss); $this->assertArrayHasKey($queryRegion, $miss); $this->assertArrayHasKey($entityRegion, $miss); $this->assertArrayHasKey($coolRegion, $put); $this->assertArrayHasKey($queryRegion, $put); $this->assertArrayHasKey($entityRegion, $put); $this->assertArrayHasKey($coolRegion, $hit); $this->assertArrayHasKey($queryRegion, $hit); $this->assertArrayHasKey($entityRegion, $hit); }
/** * Log an entity get from second level cache resulted in a hit. * * @param string $regionName The name of the cache region. * @param \Doctrine\ORM\Cache\CollectionCacheKey $key The cache key of the collection. */ public function collectionCacheHit($regionName, CollectionCacheKey $key) { parent::collectionCacheHit($regionName, $key); }