From 9f0c3d9fceea863e5fee4a0857aaaad85fc19729 Mon Sep 17 00:00:00 2001 From: Alex Pott <alex.a.pott@googlemail.com> Date: Fri, 23 Feb 2024 14:20:50 +0000 Subject: [PATCH] Issue #3423329 by catch, kristiaanvandeneynde, dww, alexpott: Prevent session garbage collection during functional tests (cherry picked from commit 4c8f1df76bc800b639a48dc479bf555d1cdf3cc4) --- .../Core/Test/FunctionalTestSetupTrait.php | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/core/lib/Drupal/Core/Test/FunctionalTestSetupTrait.php b/core/lib/Drupal/Core/Test/FunctionalTestSetupTrait.php index e2cfcbb07c94..363eba0bf0ef 100644 --- a/core/lib/Drupal/Core/Test/FunctionalTestSetupTrait.php +++ b/core/lib/Drupal/Core/Test/FunctionalTestSetupTrait.php @@ -129,13 +129,17 @@ protected function prepareSettings() { // Otherwise, use the default services as a starting point for overrides. $settings_services_file = DRUPAL_ROOT . '/sites/default/default.services.yml'; } - // Copy the testing-specific service overrides in place. - copy($settings_services_file, $directory . '/services.yml'); + + // Put the testing-specific service overrides in place. + $yaml = new SymfonyYaml(); + $content = file_get_contents($settings_services_file); + // Disable session garbage collection since test environments do not last + // long enough to have stale sessions. This prevents random delete queries + // from running during tests. + $services = $yaml->parse($content); + $services['parameters']['session.storage.options']['gc_probability'] = 0; if ($this->strictConfigSchema) { // Add a listener to validate configuration schema on save. - $yaml = new SymfonyYaml(); - $content = file_get_contents($directory . '/services.yml'); - $services = $yaml->parse($content); $test_file_name = (new \ReflectionClass($this))->getFileName(); // @todo Decide in https://www.drupal.org/project/drupal/issues/3395099 when/how to trigger deprecation errors or even failures for contrib modules. $is_core_test = str_starts_with($test_file_name, DRUPAL_ROOT . DIRECTORY_SEPARATOR . 'core'); @@ -144,8 +148,8 @@ protected function prepareSettings() { 'arguments' => ['@config.typed', $this->getConfigSchemaExclusions(), $is_core_test], 'tags' => [['name' => 'event_subscriber']], ]; - file_put_contents($directory . '/services.yml', $yaml->dump($services)); } + file_put_contents($directory . '/services.yml', $yaml->dump($services)); // Since Drupal is bootstrapped already, install_begin_request() will not // bootstrap again. Hence, we have to reload the newly written custom // settings.php manually. -- GitLab