From aa17a6c8b500db0ab35de1ce4a86b07b60128727 Mon Sep 17 00:00:00 2001 From: Saleh Saeed Date: Tue, 1 Jun 2021 23:57:02 +0200 Subject: [PATCH 1/4] Fix Charset passed via URL is overridden (#1363) --- ConnectionFactory.php | 14 ++++++++------ Tests/ConnectionFactoryTest.php | 7 +++++++ 2 files changed, 15 insertions(+), 6 deletions(-) diff --git a/ConnectionFactory.php b/ConnectionFactory.php index 7640ed3d3..28078b93f 100644 --- a/ConnectionFactory.php +++ b/ConnectionFactory.php @@ -81,14 +81,16 @@ public function createConnection(array $params, ?Configuration $config = null, ? $params['dbname'] .= $params['dbname_suffix']; } - if ($driver instanceof AbstractMySQLDriver) { - $params['charset'] = 'utf8mb4'; + if (! isset($params['charset'])) { + if ($driver instanceof AbstractMySQLDriver) { + $params['charset'] = 'utf8mb4'; - if (! isset($params['defaultTableOptions']['collate'])) { - $params['defaultTableOptions']['collate'] = 'utf8mb4_unicode_ci'; + if (! isset($params['defaultTableOptions']['collate'])) { + $params['defaultTableOptions']['collate'] = 'utf8mb4_unicode_ci'; + } + } else { + $params['charset'] = 'utf8'; } - } else { - $params['charset'] = 'utf8'; } if ($wrapperClass !== null) { diff --git a/Tests/ConnectionFactoryTest.php b/Tests/ConnectionFactoryTest.php index fd68d6748..b9fdfa77c 100644 --- a/Tests/ConnectionFactoryTest.php +++ b/Tests/ConnectionFactoryTest.php @@ -98,6 +98,13 @@ public function testConnectionOverrideOptions(): void $this->assertEquals($params, array_intersect_key($connection->getParams(), $params)); } + public function testConnectionCharsetFromUrl() + { + $connection = (new ConnectionFactory([]))->createConnection(['url' => 'mysql://root:password@database:3306/main?charset=utf8mb4_unicode_ci']); + + $this->assertEquals('utf8mb4_unicode_ci', $connection->getParams()['charset']); + } + public function testDbnameSuffix(): void { $connection = (new ConnectionFactory([]))->createConnection([ From 3242af8c62219dbbe6a9db258e8514b29d4e55d6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andreas=20Fr=C3=B6mer?= Date: Wed, 2 Jun 2021 14:56:03 +0200 Subject: [PATCH 2/4] Make configuration error message better understandable (#1367) --- DependencyInjection/Configuration.php | 4 ++-- Tests/DependencyInjection/AbstractDoctrineExtensionTest.php | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/DependencyInjection/Configuration.php b/DependencyInjection/Configuration.php index 6ff8882ef..4fa5f2971 100644 --- a/DependencyInjection/Configuration.php +++ b/DependencyInjection/Configuration.php @@ -94,7 +94,7 @@ private function addDbalSection(ArrayNodeDefinition $node): void } if ($connection && $hasExplicitlyDefinedConnectionsAtLeastOnce) { - throw new InvalidArgumentException('Either explicitly define DBAL connections in all doctrine-bundle configuration files, or in none of them'); + throw new InvalidArgumentException('Seems like you have configured multiple "dbal" connections. You need to use the long configuration syntax in every doctrine configuration file, or in none of them.'); } $v['default_connection'] = isset($v['default_connection']) ? (string) $v['default_connection'] : 'default'; @@ -413,7 +413,7 @@ private function addOrmSection(ArrayNodeDefinition $node): void } if ($entityManager && $hasExplicitlyDefinedEntityManagersAtLeastOnce) { - throw new InvalidArgumentException('Either explicitly define entity managers in all doctrine-bundle configuration files, or in none of them'); + throw new InvalidArgumentException('Seems like you have configured multiple "entity_managers". You need to use the long configuration syntax in every doctrine configuration file, or in none of them.'); } $v['default_entity_manager'] = isset($v['default_entity_manager']) ? (string) $v['default_entity_manager'] : 'default'; diff --git a/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php b/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php index 1ee2210e4..83f021a01 100644 --- a/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php +++ b/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php @@ -218,13 +218,13 @@ class_exists(PrimaryReadReplicaConnection::class) ? public function testMixedUseOfSimplifiedAndMultipleConnectionsStyleIsInvalid(): void { - $this->expectExceptionObject(new InvalidArgumentException('Either explicitly define DBAL connections in all doctrine-bundle configuration files, or in none of them')); + $this->expectExceptionObject(new InvalidArgumentException('Seems like you have configured multiple "dbal" connections. You need to use the long configuration syntax in every doctrine configuration file, or in none of them.')); $this->loadContainer('dbal_service_{single,multiple}_connectio{n,ns}'); } public function testMixedUseOfSimplifiedAndMultipleEntityManagersStyleIsInvalid(): void { - $this->expectExceptionObject(new InvalidArgumentException('Either explicitly define entity managers in all doctrine-bundle configuration files, or in none of them')); + $this->expectExceptionObject(new InvalidArgumentException('Seems like you have configured multiple "entity_managers". You need to use the long configuration syntax in every doctrine configuration file, or in none of them.')); $this->loadContainer('orm_service_{simple_single,multiple}_entity_manage{r,rs}'); } From 4decb9352208847e45254b14bac01d3622f2a37f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gabriel=20Ostroluck=C3=BD?= Date: Wed, 2 Jun 2021 23:35:09 +0200 Subject: [PATCH 3/4] Revert "Disallow mixed use of simplified and non-simplified configuration" This reverts problematic parts of commit 759018e8 We will go with something else instead. Most likely deprecating it in some form and trigger error later. --- DependencyInjection/Configuration.php | 39 ++++++------------- .../AbstractDoctrineExtensionTest.php | 12 ------ UPGRADE-2.4.md | 30 -------------- 3 files changed, 11 insertions(+), 70 deletions(-) diff --git a/DependencyInjection/Configuration.php b/DependencyInjection/Configuration.php index 4fa5f2971..1a1a60f85 100644 --- a/DependencyInjection/Configuration.php +++ b/DependencyInjection/Configuration.php @@ -3,7 +3,6 @@ namespace Doctrine\Bundle\DoctrineBundle\DependencyInjection; use Doctrine\ORM\EntityManager; -use InvalidArgumentException; use ReflectionClass; use Symfony\Component\Config\Definition\BaseNode; use Symfony\Component\Config\Definition\Builder\ArrayNodeDefinition; @@ -13,6 +12,7 @@ use Symfony\Component\DependencyInjection\Exception\LogicException; use function array_intersect_key; +use function array_key_exists; use function array_keys; use function array_pop; use function assert; @@ -72,15 +72,10 @@ private function addDbalSection(ArrayNodeDefinition $node): void ->children() ->arrayNode('dbal') ->beforeNormalization() - ->always(static function (array $v): array { - static $hasExplicitlyDefinedConnectionsAtLeastOnce = false; - - if (isset($v['connections']) || isset($v['connection'])) { - $hasExplicitlyDefinedConnectionsAtLeastOnce = true; - - return $v; - } - + ->ifTrue(static function ($v) { + return is_array($v) && ! array_key_exists('connections', $v) && ! array_key_exists('connection', $v); + }) + ->then(static function ($v) { // Key that should not be rewritten to the connection config $excludedKeys = ['default_connection' => true, 'types' => true, 'type' => true]; $connection = []; @@ -93,10 +88,6 @@ private function addDbalSection(ArrayNodeDefinition $node): void unset($v[$key]); } - if ($connection && $hasExplicitlyDefinedConnectionsAtLeastOnce) { - throw new InvalidArgumentException('Seems like you have configured multiple "dbal" connections. You need to use the long configuration syntax in every doctrine configuration file, or in none of them.'); - } - $v['default_connection'] = isset($v['default_connection']) ? (string) $v['default_connection'] : 'default'; $v['connections'] = [$v['default_connection'] => $connection]; @@ -380,19 +371,15 @@ private function addOrmSection(ArrayNodeDefinition $node): void ->children() ->arrayNode('orm') ->beforeNormalization() - ->always(static function (array $v): array { - if ($v && ! class_exists(EntityManager::class)) { + ->ifTrue(static function ($v) { + if (! empty($v) && ! class_exists(EntityManager::class)) { throw new LogicException('The doctrine/orm package is required when the doctrine.orm config is set.'); } - static $hasExplicitlyDefinedEntityManagersAtLeastOnce = false; - - if (isset($v['entity_managers']) || isset($v['entity_manager'])) { - $hasExplicitlyDefinedEntityManagersAtLeastOnce = true; - - return $v; - } - + return $v === null || (is_array($v) && ! array_key_exists('entity_managers', $v) && ! array_key_exists('entity_manager', $v)); + }) + ->then(static function ($v) { + $v = (array) $v; // Key that should not be rewritten to the connection config $excludedKeys = [ 'default_entity_manager' => true, @@ -412,10 +399,6 @@ private function addOrmSection(ArrayNodeDefinition $node): void unset($v[$key]); } - if ($entityManager && $hasExplicitlyDefinedEntityManagersAtLeastOnce) { - throw new InvalidArgumentException('Seems like you have configured multiple "entity_managers". You need to use the long configuration syntax in every doctrine configuration file, or in none of them.'); - } - $v['default_entity_manager'] = isset($v['default_entity_manager']) ? (string) $v['default_entity_manager'] : 'default'; $v['entity_managers'] = [$v['default_entity_manager'] => $entityManager]; diff --git a/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php b/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php index 83f021a01..a6634341d 100644 --- a/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php +++ b/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php @@ -216,18 +216,6 @@ class_exists(PrimaryReadReplicaConnection::class) ? $this->assertEquals(['engine' => 'InnoDB'], $param['defaultTableOptions']); } - public function testMixedUseOfSimplifiedAndMultipleConnectionsStyleIsInvalid(): void - { - $this->expectExceptionObject(new InvalidArgumentException('Seems like you have configured multiple "dbal" connections. You need to use the long configuration syntax in every doctrine configuration file, or in none of them.')); - $this->loadContainer('dbal_service_{single,multiple}_connectio{n,ns}'); - } - - public function testMixedUseOfSimplifiedAndMultipleEntityManagersStyleIsInvalid(): void - { - $this->expectExceptionObject(new InvalidArgumentException('Seems like you have configured multiple "entity_managers". You need to use the long configuration syntax in every doctrine configuration file, or in none of them.')); - $this->loadContainer('orm_service_{simple_single,multiple}_entity_manage{r,rs}'); - } - public function testDbalLoadPoolShardingConnection(): void { $container = $this->loadContainer('dbal_service_pool_sharding_connection'); diff --git a/UPGRADE-2.4.md b/UPGRADE-2.4.md index a143c259a..a6686db39 100644 --- a/UPGRADE-2.4.md +++ b/UPGRADE-2.4.md @@ -7,36 +7,6 @@ Configuration * Setting the `host`, `port`, `user`, `password`, `path`, `dbname`, `unix_socket` or `memory` configuration options while the `url` one is set has been deprecated. * The `override_url` configuration option has been deprecated. - * Combined use of simplified connection configuration in DBAL (without `connections` key) - and multiple connection configuration is disallowed now. If you experience this issue, instead of -```yaml -doctrine: - dbal: - url: '%env(DATABASE_URL)%' -``` -use -```yaml -doctrine: - dbal: - connections: - default: - url: '%env(DATABASE_URL)%' -``` -* Combined use of simplified entity manager configuration in ORM (without `entity_managers` key) - and multiple entity managers configuration is disallowed now. If you experience this issue, instead of -```yaml -doctrine: - orm: - mappings: -``` -use -```yaml -doctrine: - orm: - entity_managers: - default: - mappings: -``` ConnectionFactory -------- From 4202ce675d29e70a8b9ee763bec021b6f44caccb Mon Sep 17 00:00:00 2001 From: Andreas Braun Date: Sat, 5 Jun 2021 15:40:39 +0200 Subject: [PATCH 4/4] Test and fix cache compatibility layer (#1365) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Gabriel Ostrolucký --- .../Compiler/CacheCompatibilityPass.php | 88 +++++++++---- .../AbstractDoctrineExtensionTest.php | 118 +++++++++++++++++- .../DoctrineExtensionTest.php | 5 + .../Fixtures/config/xml/orm_caches.xml | 71 +++++++++++ .../Fixtures/config/yml/orm_caches.yml | 76 +++++++++++ 5 files changed, 331 insertions(+), 27 deletions(-) create mode 100644 Tests/DependencyInjection/Fixtures/config/xml/orm_caches.xml create mode 100644 Tests/DependencyInjection/Fixtures/config/yml/orm_caches.yml diff --git a/DependencyInjection/Compiler/CacheCompatibilityPass.php b/DependencyInjection/Compiler/CacheCompatibilityPass.php index 3e4489f86..83b62d8fc 100644 --- a/DependencyInjection/Compiler/CacheCompatibilityPass.php +++ b/DependencyInjection/Compiler/CacheCompatibilityPass.php @@ -9,9 +9,11 @@ use Symfony\Component\DependencyInjection\ChildDefinition; use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface; use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\DependencyInjection\Definition; use Symfony\Component\DependencyInjection\Reference; use function array_keys; +use function assert; use function is_a; use function trigger_deprecation; @@ -29,44 +31,80 @@ public function process(ContainerBuilder $container): void { foreach (array_keys($container->findTaggedServiceIds(self::CONFIGURATION_TAG)) as $id) { foreach ($container->getDefinition($id)->getMethodCalls() as $methodCall) { + if ($methodCall[0] === 'setSecondLevelCacheConfiguration') { + $this->updateSecondLevelCache($container, $methodCall[1][0]); + continue; + } + if (! isset(self::CACHE_METHODS_PSR6_SUPPORT_MAP[$methodCall[0]])) { continue; } $aliasId = (string) $methodCall[1][0]; $definitionId = (string) $container->getAlias($aliasId); - $definition = $container->getDefinition($definitionId); $shouldBePsr6 = self::CACHE_METHODS_PSR6_SUPPORT_MAP[$methodCall[0]]; - while (! $definition->getClass() && $definition instanceof ChildDefinition) { - $definition = $container->findDefinition($definition->getParent()); - } + $this->wrapIfNecessary($container, $aliasId, $definitionId, $shouldBePsr6); + } + } + } - if ($shouldBePsr6 === is_a($definition->getClass(), CacheItemPoolInterface::class, true)) { - continue; - } + private function updateSecondLevelCache(ContainerBuilder $container, Definition $slcConfigDefinition): void + { + foreach ($slcConfigDefinition->getMethodCalls() as $methodCall) { + if ($methodCall[0] !== 'setCacheFactory') { + continue; + } - $targetClass = CacheProvider::class; - $targetFactory = DoctrineProvider::class; + $factoryDefinition = $methodCall[1][0]; + assert($factoryDefinition instanceof Definition); + $aliasId = (string) $factoryDefinition->getArgument(1); + $this->wrapIfNecessary($container, $aliasId, (string) $container->getAlias($aliasId), false); + break; + } + } - if ($shouldBePsr6) { - $targetClass = CacheItemPoolInterface::class; - $targetFactory = CacheAdapter::class; + private function createCompatibilityLayerDefinition(ContainerBuilder $container, string $definitionId, bool $shouldBePsr6): ?Definition + { + $definition = $container->getDefinition($definitionId); - trigger_deprecation( - 'doctrine/doctrine-bundle', - '2.4', - 'Configuring doctrine/cache is deprecated. Please update the cache service "%s" to use a PSR-6 cache.', - $definitionId - ); - } + while (! $definition->getClass() && $definition instanceof ChildDefinition) { + $definition = $container->findDefinition($definition->getParent()); + } - $compatibilityLayerId = $definitionId . '.compatibility_layer'; - $container->setAlias($aliasId, $compatibilityLayerId); - $container->register($compatibilityLayerId, $targetClass) - ->setFactory([$targetFactory, 'wrap']) - ->addArgument(new Reference($definitionId)); - } + if ($shouldBePsr6 === is_a($definition->getClass(), CacheItemPoolInterface::class, true)) { + return null; + } + + $targetClass = CacheProvider::class; + $targetFactory = DoctrineProvider::class; + + if ($shouldBePsr6) { + $targetClass = CacheItemPoolInterface::class; + $targetFactory = CacheAdapter::class; + + trigger_deprecation( + 'doctrine/doctrine-bundle', + '2.4', + 'Configuring doctrine/cache is deprecated. Please update the cache service "%s" to use a PSR-6 cache.', + $definitionId + ); } + + return (new Definition($targetClass)) + ->setFactory([$targetFactory, 'wrap']) + ->addArgument(new Reference($definitionId)); + } + + private function wrapIfNecessary(ContainerBuilder $container, string $aliasId, string $definitionId, bool $shouldBePsr6): void + { + $compatibilityLayer = $this->createCompatibilityLayerDefinition($container, $definitionId, $shouldBePsr6); + if ($compatibilityLayer === null) { + return; + } + + $compatibilityLayerId = $definitionId . '.compatibility_layer'; + $container->setAlias($aliasId, $compatibilityLayerId); + $container->setDefinition($compatibilityLayerId, $compatibilityLayer); } } diff --git a/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php b/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php index a6634341d..674efeaa1 100644 --- a/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php +++ b/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php @@ -14,6 +14,7 @@ use Doctrine\DBAL\Connections\MasterSlaveConnection; use Doctrine\DBAL\Connections\PrimaryReadReplicaConnection; use Doctrine\DBAL\DriverManager; +use Doctrine\ORM\EntityManager; use Doctrine\ORM\EntityManagerInterface; use Generator; use InvalidArgumentException; @@ -681,6 +682,120 @@ public function testSetQuoteStrategy(): void $this->assertDICDefinitionMethodCallOnce($def2, 'setQuoteStrategy', [0 => new Reference('doctrine.orm.quote_strategy.ansi')]); } + /** + * @dataProvider cacheConfigProvider + * @group legacy + */ + public function testCacheConfig(?string $expectedClass, string $entityManagerName, ?string $cacheGetter): void + { + if (! interface_exists(EntityManagerInterface::class)) { + self::markTestSkipped('This test requires ORM'); + } + + $container = $this->loadContainer('orm_caches'); + + $entityManagerId = sprintf('doctrine.orm.%s_entity_manager', $entityManagerName); + + $em = $container->get($entityManagerId); + assert($em instanceof EntityManager); + + $this->assertInstanceOf(EntityManagerInterface::class, $em); + + if ($cacheGetter === null) { + return; + } + + $configuration = $em->getConfiguration(); + $cache = $configuration->$cacheGetter(); + + if ($expectedClass === null) { + $this->assertNull($cache); + } else { + $this->assertInstanceOf($expectedClass, $cache); + } + } + + public static function cacheConfigProvider(): Generator + { + yield 'metadata_cache_none' => [ + 'expectedClass' => PhpArrayAdapter::class, + 'entityManagerName' => 'metadata_cache_none', + 'cacheGetter' => 'getMetadataCache', + ]; + + yield 'metadata_cache_pool' => [ + 'expectedClass' => ArrayAdapter::class, + 'entityManagerName' => 'metadata_cache_pool', + 'cacheGetter' => 'getMetadataCache', + ]; + + yield 'metadata_cache_service_psr6' => [ + 'expectedClass' => ArrayAdapter::class, + 'entityManagerName' => 'metadata_cache_service_psr6', + 'cacheGetter' => 'getMetadataCache', + ]; + + yield 'metadata_cache_service_doctrine' => [ + 'expectedClass' => ArrayAdapter::class, + 'entityManagerName' => 'metadata_cache_service_doctrine', + 'cacheGetter' => 'getMetadataCache', + ]; + + yield 'query_cache_pool' => [ + 'expectedClass' => DoctrineProvider::class, + 'entityManagerName' => 'query_cache_pool', + 'cacheGetter' => 'getQueryCacheImpl', + ]; + + yield 'query_cache_service_psr6' => [ + 'expectedClass' => DoctrineProvider::class, + 'entityManagerName' => 'query_cache_service_psr6', + 'cacheGetter' => 'getQueryCacheImpl', + ]; + + yield 'query_cache_service_doctrine' => [ + 'expectedClass' => DoctrineProvider::class, + 'entityManagerName' => 'query_cache_service_doctrine', + 'cacheGetter' => 'getQueryCacheImpl', + ]; + + yield 'result_cache_pool' => [ + 'expectedClass' => DoctrineProvider::class, + 'entityManagerName' => 'result_cache_pool', + 'cacheGetter' => 'getResultCacheImpl', + ]; + + yield 'result_cache_service_psr6' => [ + 'expectedClass' => DoctrineProvider::class, + 'entityManagerName' => 'result_cache_service_psr6', + 'cacheGetter' => 'getResultCacheImpl', + ]; + + yield 'result_cache_service_doctrine' => [ + 'expectedClass' => DoctrineProvider::class, + 'entityManagerName' => 'result_cache_service_doctrine', + 'cacheGetter' => 'getResultCacheImpl', + ]; + + yield 'second_level_cache_pool' => [ + 'expectedClass' => null, + 'entityManagerName' => 'second_level_cache_pool', + 'cacheGetter' => null, + ]; + + yield 'second_level_cache_service_psr6' => [ + 'expectedClass' => null, + 'entityManagerName' => 'second_level_cache_service_psr6', + 'cacheGetter' => null, + ]; + + yield 'second_level_cache_service_doctrine' => [ + 'expectedClass' => null, + 'entityManagerName' => 'second_level_cache_service_doctrine', + 'cacheGetter' => null, + ]; + } + public function testSecondLevelCache(): void { if (! interface_exists(EntityManagerInterface::class)) { @@ -723,7 +838,7 @@ public function testSecondLevelCache(): void $this->assertDICDefinitionClass($myEntityRegionDef, '%doctrine.orm.second_level_cache.default_region.class%'); $this->assertDICDefinitionClass($loggerChainDef, '%doctrine.orm.second_level_cache.logger_chain.class%'); $this->assertDICDefinitionClass($loggerStatisticsDef, '%doctrine.orm.second_level_cache.logger_statistics.class%'); - $this->assertDICDefinitionClass($cacheDriverDef, ArrayAdapter::class); + $this->assertDICDefinitionClass($cacheDriverDef, CacheProvider::class); $this->assertDICDefinitionMethodCallOnce($configDef, 'setSecondLevelCacheConfiguration'); $this->assertDICDefinitionMethodCallCount($slcFactoryDef, 'setRegion', [], 3); $this->assertDICDefinitionMethodCallCount($loggerChainDef, 'setLogger', [], 3); @@ -1269,7 +1384,6 @@ private function loadContainer( ): ContainerBuilder { $container = $this->getContainer($bundles); $container->registerExtension(new DoctrineExtension()); - $container->addCompilerPass(new CacheCompatibilityPass()); $this->loadFromFile($container, $fixture); diff --git a/Tests/DependencyInjection/DoctrineExtensionTest.php b/Tests/DependencyInjection/DoctrineExtensionTest.php index fb387eaa7..f0dece540 100644 --- a/Tests/DependencyInjection/DoctrineExtensionTest.php +++ b/Tests/DependencyInjection/DoctrineExtensionTest.php @@ -1081,6 +1081,9 @@ public function testShardManager(): void $this->assertEquals($managerClass, $bazManagerDef->getClass()); } + // Disabled to prevent changing the comment below to a single-line annotation + // phpcs:disable SlevomatCodingStandard.Commenting.RequireOneLineDocComment.MultiLineDocComment + /** * @requires PHP 8 */ @@ -1118,6 +1121,8 @@ public function testAsEntityListenerAttribute() $this->assertSame([$expected], $definition->getTag('doctrine.orm.entity_listener')); } + // phpcs:enable + /** @param list $bundles */ private function getContainer(array $bundles = ['YamlBundle'], string $vendor = ''): ContainerBuilder { diff --git a/Tests/DependencyInjection/Fixtures/config/xml/orm_caches.xml b/Tests/DependencyInjection/Fixtures/config/xml/orm_caches.xml new file mode 100644 index 000000000..dbe5b80d4 --- /dev/null +++ b/Tests/DependencyInjection/Fixtures/config/xml/orm_caches.xml @@ -0,0 +1,71 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/Tests/DependencyInjection/Fixtures/config/yml/orm_caches.yml b/Tests/DependencyInjection/Fixtures/config/yml/orm_caches.yml new file mode 100644 index 000000000..987388247 --- /dev/null +++ b/Tests/DependencyInjection/Fixtures/config/yml/orm_caches.yml @@ -0,0 +1,76 @@ +services: + cache.psr6: + class: Symfony\Component\Cache\Adapter\ArrayAdapter + cache.doctrine: + class: Doctrine\Common\Cache\Psr6\DoctrineProvider + factory: [Doctrine\Common\Cache\Psr6\DoctrineProvider, wrap] + arguments: ["@cache.psr6"] + +doctrine: + dbal: + default_connection: default + connections: + default: + dbname: db + + orm: + default_entity_manager: metadata_cache_none + entity_managers: + metadata_cache_none: ~ + metadata_cache_pool: + metadata_cache_driver: + type: pool + pool: cache.psr6 + metadata_cache_service_psr6: + metadata_cache_driver: + type: service + id: cache.psr6 + metadata_cache_service_doctrine: + metadata_cache_driver: + type: service + id: cache.doctrine + + query_cache_pool: + query_cache_driver: + type: pool + pool: cache.psr6 + query_cache_service_psr6: + query_cache_driver: + type: service + id: cache.psr6 + query_cache_service_doctrine: + query_cache_driver: + type: service + id: cache.doctrine + + result_cache_pool: + result_cache_driver: + type: pool + pool: cache.psr6 + result_cache_service_psr6: + result_cache_driver: + type: service + id: cache.psr6 + result_cache_service_doctrine: + result_cache_driver: + type: service + id: cache.doctrine + + second_level_cache_pool: + second_level_cache: + enabled: true + region_cache_driver: + type: pool + pool: cache.psr6 + second_level_cache_service_psr6: + second_level_cache: + enabled: true + region_cache_driver: + type: service + id: cache.psr6 + second_level_cache_service_doctrine: + second_level_cache: + enabled: true + region_cache_driver: + type: service + id: cache.doctrine