2009-05-21 19:18:14 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\ORM\Functional;
|
|
|
|
|
|
|
|
use Doctrine\Tests\Models\CMS\CmsUser;
|
2009-07-06 20:34:54 +00:00
|
|
|
use Doctrine\Common\Cache\ArrayCache;
|
2009-05-21 19:18:14 +00:00
|
|
|
|
|
|
|
require_once __DIR__ . '/../../TestInit.php';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* QueryCacheTest
|
|
|
|
*
|
|
|
|
* @author robo
|
|
|
|
*/
|
|
|
|
class QueryCacheTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|
|
|
{
|
|
|
|
protected function setUp() {
|
|
|
|
$this->useModelSet('cms');
|
|
|
|
parent::setUp();
|
|
|
|
}
|
|
|
|
|
2010-02-10 19:09:25 +00:00
|
|
|
public function testQueryCache_DependsOnHints()
|
2009-05-21 19:18:14 +00:00
|
|
|
{
|
2010-02-10 19:09:25 +00:00
|
|
|
$query = $this->_em->createQuery('select ux from Doctrine\Tests\Models\CMS\CmsUser ux');
|
|
|
|
|
|
|
|
$cache = new ArrayCache();
|
|
|
|
$query->setQueryCacheDriver($cache);
|
2010-01-29 01:38:37 +00:00
|
|
|
|
2010-02-10 19:09:25 +00:00
|
|
|
$query->getResult();
|
|
|
|
$this->assertEquals(1, count($cache->getIds()));
|
|
|
|
|
|
|
|
$query->setHint('foo', 'bar');
|
|
|
|
|
|
|
|
$query->getResult();
|
|
|
|
$this->assertEquals(2, count($cache->getIds()));
|
|
|
|
|
|
|
|
return $query;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param <type> $query
|
|
|
|
* @depends testQueryCache_DependsOnHints
|
|
|
|
*/
|
|
|
|
public function testQueryCache_DependsOnFirstResult($query)
|
|
|
|
{
|
|
|
|
$cache = $query->getQueryCacheDriver();
|
|
|
|
$cacheCount = count($cache->getIds());
|
|
|
|
|
|
|
|
$query->setFirstResult(10);
|
2010-02-25 15:47:20 +00:00
|
|
|
$query->setMaxResults(9999);
|
2010-02-10 19:09:25 +00:00
|
|
|
|
|
|
|
$query->getResult();
|
|
|
|
$this->assertEquals($cacheCount + 1, count($cache->getIds()));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param <type> $query
|
|
|
|
* @depends testQueryCache_DependsOnHints
|
|
|
|
*/
|
|
|
|
public function testQueryCache_DependsOnMaxResults($query)
|
|
|
|
{
|
|
|
|
$cache = $query->getQueryCacheDriver();
|
|
|
|
$cacheCount = count($cache->getIds());
|
2009-05-21 19:18:14 +00:00
|
|
|
|
2010-02-10 19:09:25 +00:00
|
|
|
$query->setMaxResults(10);
|
|
|
|
|
|
|
|
$query->getResult();
|
|
|
|
$this->assertEquals($cacheCount + 1, count($cache->getIds()));
|
|
|
|
}
|
|
|
|
|
2010-02-13 21:42:09 +00:00
|
|
|
/**
|
|
|
|
* @param <type> $query
|
|
|
|
* @depends testQueryCache_DependsOnHints
|
|
|
|
*/
|
|
|
|
public function testQueryCache_DependsOnHydrationMode($query)
|
|
|
|
{
|
|
|
|
$cache = $query->getQueryCacheDriver();
|
|
|
|
$cacheCount = count($cache->getIds());
|
|
|
|
|
|
|
|
$query->getArrayResult();
|
|
|
|
$this->assertEquals($cacheCount + 1, count($cache->getIds()));
|
|
|
|
}
|
|
|
|
|
2010-02-10 19:09:25 +00:00
|
|
|
public function testQueryCache_NoHitSaveParserResult()
|
|
|
|
{
|
2010-04-10 17:35:18 +02:00
|
|
|
$this->_em->getConfiguration()->setQueryCacheImpl(new ArrayCache());
|
2009-05-21 19:18:14 +00:00
|
|
|
|
|
|
|
$query = $this->_em->createQuery('select ux from Doctrine\Tests\Models\CMS\CmsUser ux');
|
2010-02-10 19:09:25 +00:00
|
|
|
|
|
|
|
$cache = $this->getMock('Doctrine\Common\Cache\AbstractCache', array('_doFetch', '_doContains', '_doSave', '_doDelete', 'getIds'));
|
|
|
|
$cache->expects($this->at(0))
|
|
|
|
->method('_doFetch')
|
|
|
|
->with($this->isType('string'))
|
|
|
|
->will($this->returnValue(false));
|
|
|
|
$cache->expects($this->at(1))
|
|
|
|
->method('_doSave')
|
|
|
|
->with($this->isType('string'), $this->isInstanceOf('Doctrine\ORM\Query\ParserResult'), $this->equalTo(null));
|
|
|
|
|
2009-05-21 19:18:14 +00:00
|
|
|
$query->setQueryCacheDriver($cache);
|
2010-01-29 01:38:37 +00:00
|
|
|
|
2009-08-03 17:18:37 +00:00
|
|
|
$users = $query->getResult();
|
2010-02-10 19:09:25 +00:00
|
|
|
}
|
2009-05-21 19:18:14 +00:00
|
|
|
|
2010-02-10 19:09:25 +00:00
|
|
|
public function testQueryCache_HitDoesNotSaveParserResult()
|
|
|
|
{
|
2010-04-10 17:35:18 +02:00
|
|
|
$this->_em->getConfiguration()->setQueryCacheImpl(new ArrayCache());
|
2010-02-10 19:09:25 +00:00
|
|
|
|
|
|
|
$query = $this->_em->createQuery('select ux from Doctrine\Tests\Models\CMS\CmsUser ux');
|
2010-01-29 01:38:37 +00:00
|
|
|
|
2010-02-10 19:09:25 +00:00
|
|
|
$sqlExecMock = $this->getMock('Doctrine\ORM\Query\Exec\AbstractSqlExecutor', array('execute'));
|
|
|
|
$sqlExecMock->expects($this->once())
|
|
|
|
->method('execute')
|
|
|
|
->will($this->returnValue( 10 ));
|
2010-01-29 01:38:37 +00:00
|
|
|
|
2010-02-10 19:09:25 +00:00
|
|
|
$parserResultMock = $this->getMock('Doctrine\ORM\Query\ParserResult');
|
|
|
|
$parserResultMock->expects($this->once())
|
|
|
|
->method('getSqlExecutor')
|
|
|
|
->will($this->returnValue($sqlExecMock));
|
2010-01-29 01:38:37 +00:00
|
|
|
|
2010-02-10 19:09:25 +00:00
|
|
|
$cache = $this->getMock('Doctrine\Common\Cache\AbstractCache', array('_doFetch', '_doContains', '_doSave', '_doDelete', 'getIds'));
|
|
|
|
$cache->expects($this->once())
|
|
|
|
->method('_doFetch')
|
|
|
|
->with($this->isType('string'))
|
|
|
|
->will($this->returnValue($parserResultMock));
|
|
|
|
$cache->expects($this->never())
|
|
|
|
->method('_doSave');
|
2010-01-29 01:38:37 +00:00
|
|
|
|
2010-02-10 19:09:25 +00:00
|
|
|
$query->setQueryCacheDriver($cache);
|
|
|
|
|
|
|
|
$users = $query->getResult();
|
2009-05-21 19:18:14 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|