2012-07-08 18:27:38 +04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\ORM;
|
|
|
|
|
2014-11-08 17:05:56 +03:00
|
|
|
use Doctrine\Common\Cache\ArrayCache;
|
2012-07-08 18:27:38 +04:00
|
|
|
use Doctrine\ORM\Mapping as AnnotationNamespace;
|
|
|
|
use Doctrine\ORM\Configuration;
|
|
|
|
use Doctrine\ORM\ORMException;
|
|
|
|
use ReflectionClass;
|
|
|
|
use PHPUnit_Framework_TestCase;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tests for the Configuration object
|
|
|
|
* @author Marco Pivetta <ocramius@gmail.com>
|
|
|
|
*/
|
|
|
|
class ConfigurationTest extends PHPUnit_Framework_TestCase
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var Configuration
|
|
|
|
*/
|
|
|
|
private $configuration;
|
|
|
|
|
|
|
|
protected function setUp()
|
|
|
|
{
|
|
|
|
parent::setUp();
|
|
|
|
$this->configuration = new Configuration();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetProxyDir()
|
|
|
|
{
|
|
|
|
$this->assertSame(null, $this->configuration->getProxyDir()); // defaults
|
|
|
|
|
|
|
|
$this->configuration->setProxyDir(__DIR__);
|
|
|
|
$this->assertSame(__DIR__, $this->configuration->getProxyDir());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetAutoGenerateProxyClasses()
|
|
|
|
{
|
|
|
|
$this->assertSame(true, $this->configuration->getAutoGenerateProxyClasses()); // defaults
|
|
|
|
|
|
|
|
$this->configuration->setAutoGenerateProxyClasses(false);
|
|
|
|
$this->assertSame(false, $this->configuration->getAutoGenerateProxyClasses());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetProxyNamespace()
|
|
|
|
{
|
|
|
|
$this->assertSame(null, $this->configuration->getProxyNamespace()); // defaults
|
|
|
|
|
|
|
|
$this->configuration->setProxyNamespace(__NAMESPACE__);
|
|
|
|
$this->assertSame(__NAMESPACE__, $this->configuration->getProxyNamespace());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetMetadataDriverImpl()
|
|
|
|
{
|
|
|
|
$this->assertSame(null, $this->configuration->getMetadataDriverImpl()); // defaults
|
|
|
|
|
|
|
|
$metadataDriver = $this->getMock('Doctrine\Common\Persistence\Mapping\Driver\MappingDriver');
|
|
|
|
$this->configuration->setMetadataDriverImpl($metadataDriver);
|
|
|
|
$this->assertSame($metadataDriver, $this->configuration->getMetadataDriverImpl());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testNewDefaultAnnotationDriver()
|
|
|
|
{
|
|
|
|
$paths = array(__DIR__);
|
|
|
|
$reflectionClass = new ReflectionClass(__NAMESPACE__ . '\ConfigurationTestAnnotationReaderChecker');
|
|
|
|
|
2012-07-08 19:33:50 +04:00
|
|
|
$annotationDriver = $this->configuration->newDefaultAnnotationDriver($paths, false);
|
2012-07-08 18:27:38 +04:00
|
|
|
$reader = $annotationDriver->getReader();
|
|
|
|
$annotation = $reader->getMethodAnnotation(
|
|
|
|
$reflectionClass->getMethod('namespacedAnnotationMethod'),
|
|
|
|
'Doctrine\ORM\Mapping\PrePersist'
|
|
|
|
);
|
|
|
|
$this->assertInstanceOf('Doctrine\ORM\Mapping\PrePersist', $annotation);
|
|
|
|
|
2012-07-08 19:33:50 +04:00
|
|
|
$annotationDriver = $this->configuration->newDefaultAnnotationDriver($paths);
|
2012-07-08 18:27:38 +04:00
|
|
|
$reader = $annotationDriver->getReader();
|
|
|
|
$annotation = $reader->getMethodAnnotation(
|
|
|
|
$reflectionClass->getMethod('simpleAnnotationMethod'),
|
|
|
|
'Doctrine\ORM\Mapping\PrePersist'
|
|
|
|
);
|
|
|
|
$this->assertInstanceOf('Doctrine\ORM\Mapping\PrePersist', $annotation);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetEntityNamespace()
|
|
|
|
{
|
|
|
|
$this->configuration->addEntityNamespace('TestNamespace', __NAMESPACE__);
|
|
|
|
$this->assertSame(__NAMESPACE__, $this->configuration->getEntityNamespace('TestNamespace'));
|
|
|
|
$namespaces = array('OtherNamespace' => __NAMESPACE__);
|
|
|
|
$this->configuration->setEntityNamespaces($namespaces);
|
|
|
|
$this->assertSame($namespaces, $this->configuration->getEntityNamespaces());
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException');
|
|
|
|
$this->configuration->getEntityNamespace('NonExistingNamespace');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetQueryCacheImpl()
|
|
|
|
{
|
|
|
|
$this->assertSame(null, $this->configuration->getQueryCacheImpl()); // defaults
|
|
|
|
$queryCacheImpl = $this->getMock('Doctrine\Common\Cache\Cache');
|
|
|
|
$this->configuration->setQueryCacheImpl($queryCacheImpl);
|
|
|
|
$this->assertSame($queryCacheImpl, $this->configuration->getQueryCacheImpl());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetHydrationCacheImpl()
|
|
|
|
{
|
|
|
|
$this->assertSame(null, $this->configuration->getHydrationCacheImpl()); // defaults
|
|
|
|
$queryCacheImpl = $this->getMock('Doctrine\Common\Cache\Cache');
|
|
|
|
$this->configuration->setHydrationCacheImpl($queryCacheImpl);
|
|
|
|
$this->assertSame($queryCacheImpl, $this->configuration->getHydrationCacheImpl());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetMetadataCacheImpl()
|
|
|
|
{
|
|
|
|
$this->assertSame(null, $this->configuration->getMetadataCacheImpl()); // defaults
|
|
|
|
$queryCacheImpl = $this->getMock('Doctrine\Common\Cache\Cache');
|
|
|
|
$this->configuration->setMetadataCacheImpl($queryCacheImpl);
|
|
|
|
$this->assertSame($queryCacheImpl, $this->configuration->getMetadataCacheImpl());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddGetNamedQuery()
|
|
|
|
{
|
|
|
|
$dql = 'SELECT u FROM User u';
|
|
|
|
$this->configuration->addNamedQuery('QueryName', $dql);
|
|
|
|
$this->assertSame($dql, $this->configuration->getNamedQuery('QueryName'));
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException');
|
|
|
|
$this->configuration->getNamedQuery('NonExistingQuery');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddGetNamedNativeQuery()
|
|
|
|
{
|
|
|
|
$sql = 'SELECT * FROM user';
|
|
|
|
$rsm = $this->getMock('Doctrine\ORM\Query\ResultSetMapping');
|
|
|
|
$this->configuration->addNamedNativeQuery('QueryName', $sql, $rsm);
|
|
|
|
$fetched = $this->configuration->getNamedNativeQuery('QueryName');
|
|
|
|
$this->assertSame($sql, $fetched[0]);
|
|
|
|
$this->assertSame($rsm, $fetched[1]);
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException');
|
|
|
|
$this->configuration->getNamedQuery('NonExistingQuery');
|
|
|
|
}
|
|
|
|
|
2014-11-08 17:05:56 +03:00
|
|
|
protected function setProductionSettings($skipCache = false)
|
2012-07-08 18:27:38 +04:00
|
|
|
{
|
|
|
|
$cache = $this->getMock('Doctrine\Common\Cache\Cache');
|
|
|
|
|
2014-11-08 17:05:56 +03:00
|
|
|
$this->configuration->setAutoGenerateProxyClasses(false);
|
|
|
|
if ($skipCache !== 'query') {
|
|
|
|
$this->configuration->setQueryCacheImpl($cache);
|
|
|
|
}
|
|
|
|
if ($skipCache !== 'metadata') {
|
|
|
|
$this->configuration->setMetadataCacheImpl($cache);
|
|
|
|
}
|
|
|
|
}
|
2012-07-08 18:27:38 +04:00
|
|
|
|
2014-11-08 17:05:56 +03:00
|
|
|
public function testEnsureProductionSettings()
|
|
|
|
{
|
|
|
|
$this->setProductionSettings();
|
|
|
|
$this->configuration->ensureProductionSettings();
|
|
|
|
}
|
2012-07-08 18:27:38 +04:00
|
|
|
|
2014-11-08 17:05:56 +03:00
|
|
|
public function testEnsureProductionSettingsQueryCache()
|
|
|
|
{
|
|
|
|
$this->setProductionSettings('query');
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException', 'Query Cache is not configured.');
|
|
|
|
$this->configuration->ensureProductionSettings();
|
|
|
|
}
|
2012-07-08 18:27:38 +04:00
|
|
|
|
2014-11-08 17:05:56 +03:00
|
|
|
public function testEnsureProductionSettingsMetadataCache()
|
|
|
|
{
|
|
|
|
$this->setProductionSettings('metadata');
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException', 'Metadata Cache is not configured.');
|
|
|
|
$this->configuration->ensureProductionSettings();
|
|
|
|
}
|
2012-07-08 18:27:38 +04:00
|
|
|
|
2014-11-08 17:05:56 +03:00
|
|
|
public function testEnsureProductionSettingsMetadataArrayCache()
|
|
|
|
{
|
|
|
|
$this->setProductionSettings();
|
|
|
|
$this->configuration->setMetadataCacheImpl(new ArrayCache());
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException', 'Metadata Cache uses ArrayCache.');
|
|
|
|
$this->configuration->ensureProductionSettings();
|
|
|
|
}
|
2012-07-08 18:27:38 +04:00
|
|
|
|
2014-11-08 17:05:56 +03:00
|
|
|
public function testEnsureProductionSettingsAutoGenerateProxyClasses()
|
|
|
|
{
|
|
|
|
$this->setProductionSettings();
|
|
|
|
$this->configuration->setAutoGenerateProxyClasses(true);
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException', 'Proxy Classes are always regenerating.');
|
2012-07-08 18:27:38 +04:00
|
|
|
$this->configuration->ensureProductionSettings();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddGetCustomStringFunction()
|
|
|
|
{
|
|
|
|
$this->configuration->addCustomStringFunction('FunctionName', __CLASS__);
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getCustomStringFunction('FunctionName'));
|
|
|
|
$this->assertSame(null, $this->configuration->getCustomStringFunction('NonExistingFunction'));
|
|
|
|
$this->configuration->setCustomStringFunctions(array('OtherFunctionName' => __CLASS__));
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getCustomStringFunction('OtherFunctionName'));
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException');
|
|
|
|
$this->configuration->addCustomStringFunction('concat', __CLASS__);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddGetCustomNumericFunction()
|
|
|
|
{
|
|
|
|
$this->configuration->addCustomNumericFunction('FunctionName', __CLASS__);
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getCustomNumericFunction('FunctionName'));
|
|
|
|
$this->assertSame(null, $this->configuration->getCustomNumericFunction('NonExistingFunction'));
|
|
|
|
$this->configuration->setCustomNumericFunctions(array('OtherFunctionName' => __CLASS__));
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getCustomNumericFunction('OtherFunctionName'));
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException');
|
|
|
|
$this->configuration->addCustomNumericFunction('abs', __CLASS__);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddGetCustomDatetimeFunction()
|
|
|
|
{
|
|
|
|
$this->configuration->addCustomDatetimeFunction('FunctionName', __CLASS__);
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getCustomDatetimeFunction('FunctionName'));
|
|
|
|
$this->assertSame(null, $this->configuration->getCustomDatetimeFunction('NonExistingFunction'));
|
|
|
|
$this->configuration->setCustomDatetimeFunctions(array('OtherFunctionName' => __CLASS__));
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getCustomDatetimeFunction('OtherFunctionName'));
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException');
|
|
|
|
$this->configuration->addCustomDatetimeFunction('date_add', __CLASS__);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddGetCustomHydrationMode()
|
|
|
|
{
|
|
|
|
$this->assertSame(null, $this->configuration->getCustomHydrationMode('NonExisting'));
|
|
|
|
$this->configuration->addCustomHydrationMode('HydrationModeName', __CLASS__);
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getCustomHydrationMode('HydrationModeName'));
|
|
|
|
}
|
|
|
|
|
2012-08-15 00:43:32 +04:00
|
|
|
public function testSetCustomHydrationModes()
|
|
|
|
{
|
|
|
|
$this->configuration->addCustomHydrationMode('HydrationModeName', __CLASS__);
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getCustomHydrationMode('HydrationModeName'));
|
|
|
|
|
|
|
|
$this->configuration->setCustomHydrationModes(
|
|
|
|
array(
|
|
|
|
'AnotherHydrationModeName' => __CLASS__
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertNull($this->configuration->getCustomHydrationMode('HydrationModeName'));
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getCustomHydrationMode('AnotherHydrationModeName'));
|
|
|
|
}
|
|
|
|
|
2012-07-08 18:27:38 +04:00
|
|
|
public function testSetGetClassMetadataFactoryName()
|
|
|
|
{
|
|
|
|
$this->assertSame('Doctrine\ORM\Mapping\ClassMetadataFactory', $this->configuration->getClassMetadataFactoryName());
|
|
|
|
$this->configuration->setClassMetadataFactoryName(__CLASS__);
|
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getClassMetadataFactoryName());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAddGetFilters()
|
|
|
|
{
|
2013-02-09 23:27:39 +04:00
|
|
|
$this->assertSame(null, $this->configuration->getFilterClassName('NonExistingFilter'));
|
2012-07-08 18:27:38 +04:00
|
|
|
$this->configuration->addFilter('FilterName', __CLASS__);
|
2013-02-09 23:27:39 +04:00
|
|
|
$this->assertSame(__CLASS__, $this->configuration->getFilterClassName('FilterName'));
|
2012-07-08 18:27:38 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
public function setDefaultRepositoryClassName()
|
|
|
|
{
|
|
|
|
$this->assertSame('Doctrine\ORM\EntityRepository', $this->configuration->getDefaultRepositoryClassName());
|
|
|
|
$repositoryClass = 'Doctrine\Tests\Models\DDC753\DDC753CustomRepository';
|
|
|
|
$this->configuration->setDefaultRepositoryClassName($repositoryClass);
|
|
|
|
$this->assertSame($repositoryClass, $this->configuration->getDefaultRepositoryClassName());
|
|
|
|
$this->setExpectedException('Doctrine\ORM\ORMException');
|
|
|
|
$this->configuration->setDefaultRepositoryClassName(__CLASS__);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetNamingStrategy()
|
|
|
|
{
|
|
|
|
$this->assertInstanceOf('Doctrine\ORM\Mapping\NamingStrategy', $this->configuration->getNamingStrategy());
|
|
|
|
$namingStrategy = $this->getMock('Doctrine\ORM\Mapping\NamingStrategy');
|
|
|
|
$this->configuration->setNamingStrategy($namingStrategy);
|
|
|
|
$this->assertSame($namingStrategy, $this->configuration->getNamingStrategy());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testSetGetQuoteStrategy()
|
|
|
|
{
|
|
|
|
$this->assertInstanceOf('Doctrine\ORM\Mapping\QuoteStrategy', $this->configuration->getQuoteStrategy());
|
|
|
|
$quoteStrategy = $this->getMock('Doctrine\ORM\Mapping\QuoteStrategy');
|
|
|
|
$this->configuration->setQuoteStrategy($quoteStrategy);
|
|
|
|
$this->assertSame($quoteStrategy, $this->configuration->getQuoteStrategy());
|
|
|
|
}
|
2012-08-13 05:10:47 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @group DDC-1955
|
|
|
|
*/
|
|
|
|
public function testSetGetEntityListenerResolver()
|
|
|
|
{
|
|
|
|
$this->assertInstanceOf('Doctrine\ORM\Mapping\EntityListenerResolver', $this->configuration->getEntityListenerResolver());
|
|
|
|
$this->assertInstanceOf('Doctrine\ORM\Mapping\DefaultEntityListenerResolver', $this->configuration->getEntityListenerResolver());
|
2012-11-09 22:57:30 +04:00
|
|
|
$resolver = $this->getMock('Doctrine\ORM\Mapping\EntityListenerResolver');
|
|
|
|
$this->configuration->setEntityListenerResolver($resolver);
|
|
|
|
$this->assertSame($resolver, $this->configuration->getEntityListenerResolver());
|
2012-08-13 05:10:47 +04:00
|
|
|
}
|
2013-02-14 02:42:13 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @group DDC-2183
|
|
|
|
*/
|
2013-10-03 21:55:55 +04:00
|
|
|
public function testSetGetSecondLevelCacheConfig()
|
2013-02-14 02:42:13 +04:00
|
|
|
{
|
2013-10-03 21:55:55 +04:00
|
|
|
$mockClass = $this->getMock('Doctrine\ORM\Cache\CacheConfiguration');
|
2013-02-14 02:42:13 +04:00
|
|
|
|
2013-10-03 21:55:55 +04:00
|
|
|
$this->assertNull($this->configuration->getSecondLevelCacheConfiguration());
|
|
|
|
$this->configuration->setSecondLevelCacheConfiguration($mockClass);
|
|
|
|
$this->assertEquals($mockClass, $this->configuration->getSecondLevelCacheConfiguration());
|
2013-02-14 02:42:13 +04:00
|
|
|
}
|
2012-07-08 18:27:38 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
class ConfigurationTestAnnotationReaderChecker
|
|
|
|
{
|
|
|
|
/** @PrePersist */
|
|
|
|
public function simpleAnnotationMethod()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/** @AnnotationNamespace\PrePersist */
|
|
|
|
public function namespacedAnnotationMethod()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|