From 9f8502c19cd9c97152d5ae3f0507fa68ac02d3df Mon Sep 17 00:00:00 2001 From: Christopher Hertel Date: Tue, 31 Oct 2023 20:41:38 +0100 Subject: [PATCH 1/4] extend dbal config and extension for result cache --- DependencyInjection/Configuration.php | 1 + DependencyInjection/DoctrineExtension.php | 4 ++++ 2 files changed, 5 insertions(+) diff --git a/DependencyInjection/Configuration.php b/DependencyInjection/Configuration.php index aba623dc..b8bce028 100644 --- a/DependencyInjection/Configuration.php +++ b/DependencyInjection/Configuration.php @@ -249,6 +249,7 @@ private function getDbalConnectionsNode(): ArrayNodeDefinition ->cannotBeEmpty() ->defaultValue($this->getDefaultSchemaManagerFactory()) ->end() + ->scalarNode('result_cache')->end() ->end(); // dbal < 2.11 diff --git a/DependencyInjection/DoctrineExtension.php b/DependencyInjection/DoctrineExtension.php index 5633d451..6fc1d9fc 100644 --- a/DependencyInjection/DoctrineExtension.php +++ b/DependencyInjection/DoctrineExtension.php @@ -303,6 +303,10 @@ protected function loadDbalConnection($name, array $connection, ContainerBuilder $configuration->addMethodCall('setSchemaManagerFactory', [new Reference($connection['schema_manager_factory'])]); + if (isset($connection['result_cache'])) { + $configuration->addMethodCall('setResultCache', [new Reference($connection['result_cache'])]); + } + if (class_exists(LegacySchemaManagerFactory::class)) { return; } From 5153ce078a3388a2dffc0d2ff12ea33ba0025cc5 Mon Sep 17 00:00:00 2001 From: Christopher Hertel Date: Wed, 1 Nov 2023 22:14:06 +0100 Subject: [PATCH 2/4] extend configuration docs --- Resources/doc/configuration.rst | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Resources/doc/configuration.rst b/Resources/doc/configuration.rst index ad4ff7d8..ffe4c9ea 100644 --- a/Resources/doc/configuration.rst +++ b/Resources/doc/configuration.rst @@ -142,6 +142,10 @@ Configuration Reference # collation: utf8mb4_unicode_ci # When using doctrine/dbal 3.x # engine: InnoDB + # Service identifier of a Psr\Cache\CacheItemPoolInterface implementation + # to use as the cache driver for dbal result sets. + result_cache: ~ + replicas: # A collection of named replica connections (e.g. replica1, replica2) replica1: From 33878a485e044cde59411a5532fbd59f108de3b6 Mon Sep 17 00:00:00 2001 From: Christopher Hertel Date: Sat, 11 Nov 2023 11:58:22 +0100 Subject: [PATCH 3/4] add result-cache to config schema xsd --- Resources/config/schema/doctrine-1.0.xsd | 1 + 1 file changed, 1 insertion(+) diff --git a/Resources/config/schema/doctrine-1.0.xsd b/Resources/config/schema/doctrine-1.0.xsd index 4a34eb34..3a9b7ab8 100644 --- a/Resources/config/schema/doctrine-1.0.xsd +++ b/Resources/config/schema/doctrine-1.0.xsd @@ -39,6 +39,7 @@ + From d4bd3a7c3a27226a7cf470754e3105b10b51164c Mon Sep 17 00:00:00 2001 From: Christopher Hertel Date: Sat, 11 Nov 2023 17:33:59 +0100 Subject: [PATCH 4/4] add config test for result cache option --- .../AbstractDoctrineExtensionTest.php | 20 +++++++++++++++++++ .../Fixtures/config/xml/dbal_result_cache.xml | 18 +++++++++++++++++ .../Fixtures/config/yml/dbal_result_cache.yml | 7 +++++++ 3 files changed, 45 insertions(+) create mode 100644 Tests/DependencyInjection/Fixtures/config/xml/dbal_result_cache.xml create mode 100644 Tests/DependencyInjection/Fixtures/config/yml/dbal_result_cache.yml diff --git a/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php b/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php index 4e9be922..1e59ba11 100644 --- a/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php +++ b/Tests/DependencyInjection/AbstractDoctrineExtensionTest.php @@ -291,6 +291,26 @@ public function testDbalSchemaManagerFactory(): void ); } + public function testDbalResultCache(): void + { + $container = $this->loadContainer('dbal_result_cache'); + + $this->assertDICDefinitionMethodCallOnce( + $container->getDefinition('doctrine.dbal.connection_with_cache_connection.configuration'), + 'setResultCache', + [ + new Reference('example.cache'), + ], + ); + + $this->assertDICDefinitionMethodCallCount( + $container->getDefinition('doctrine.dbal.connection_without_cache_connection.configuration'), + 'setResultCache', + [], + 0, + ); + } + public function testLoadSimpleSingleConnection(): void { if (! interface_exists(EntityManagerInterface::class)) { diff --git a/Tests/DependencyInjection/Fixtures/config/xml/dbal_result_cache.xml b/Tests/DependencyInjection/Fixtures/config/xml/dbal_result_cache.xml new file mode 100644 index 00000000..f2c9450a --- /dev/null +++ b/Tests/DependencyInjection/Fixtures/config/xml/dbal_result_cache.xml @@ -0,0 +1,18 @@ + + + + + + + + + + + diff --git a/Tests/DependencyInjection/Fixtures/config/yml/dbal_result_cache.yml b/Tests/DependencyInjection/Fixtures/config/yml/dbal_result_cache.yml new file mode 100644 index 00000000..4a92be0a --- /dev/null +++ b/Tests/DependencyInjection/Fixtures/config/yml/dbal_result_cache.yml @@ -0,0 +1,7 @@ +doctrine: + dbal: + default_connection: connection_with_cache + connections: + connection_with_cache: + result_cache: example.cache + connection_without_cache: ~