diff --git a/core/lib/Drupal/Core/Form/FormBuilder.php b/core/lib/Drupal/Core/Form/FormBuilder.php index 4dd4afec0b9fc9535ae9d399abae57cc4c94650c..c0542759f0fe39bda85a18605bc9b45096c76a3d 100644 --- a/core/lib/Drupal/Core/Form/FormBuilder.php +++ b/core/lib/Drupal/Core/Form/FormBuilder.php @@ -348,10 +348,9 @@ public function buildForm($form_arg, FormStateInterface &$form_state) { // throwing an exception. // @see Drupal\Core\EventSubscriber\EnforcedFormResponseSubscriber // - // @todo Exceptions should not be used for code flow control. However, the - // Form API does not integrate with the HTTP Kernel based architecture of - // Drupal 8. In order to resolve this issue properly it is necessary to - // completely separate form submission from rendering. + // @todo Exceptions should not be used for code flow control. In order to + // resolve this issue properly it is necessary to completely separate form + // submission from rendering. // @see https://www.drupal.org/node/2367555 if ($response instanceof Response) { throw new EnforcedResponseException($response); @@ -831,6 +830,10 @@ public function prepareForm($form_id, &$form, FormStateInterface &$form_state) { } } + // Add the 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form' cache tag to + // identify this render array as a form to the render cache. + $form['#cache']['tags'][] = 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form'; + // Invoke hook_form_alter(), hook_form_BASE_FORM_ID_alter(), and // hook_form_FORM_ID_alter() implementations. $hooks = ['form']; diff --git a/core/lib/Drupal/Core/Render/PlaceholderingRenderCache.php b/core/lib/Drupal/Core/Render/PlaceholderingRenderCache.php index 4848285d7e0951a99f349738677ed1845a7e2019..d1bd1af90a72b2c938802ee55d0a2c3d879951fa 100644 --- a/core/lib/Drupal/Core/Render/PlaceholderingRenderCache.php +++ b/core/lib/Drupal/Core/Render/PlaceholderingRenderCache.php @@ -96,10 +96,6 @@ public function __construct(RequestStack $request_stack, $cache_factory, CacheCo * {@inheritdoc} */ public function get(array $elements) { - // @todo remove this check when https://www.drupal.org/node/2367555 lands. - if (!$this->requestStack->getCurrentRequest()->isMethodCacheable()) { - return FALSE; - } // When rendering placeholders, special case auto-placeholdered elements: // avoid retrieving them from cache again, or rendering them again. @@ -130,7 +126,9 @@ public function get(array $elements) { public function set(array &$elements, array $pre_bubbling_elements) { $result = parent::set($elements, $pre_bubbling_elements); - // @todo remove this check when https://www.drupal.org/node/2367555 lands. + // Writes to the render cache are disabled on uncacheable HTTP requests, to + // prevent very low hit rate items from being written. If we're not writing + // to the cache, there's also no benefit to placeholdering either. if (!$this->requestStack->getCurrentRequest()->isMethodCacheable()) { return FALSE; } diff --git a/core/lib/Drupal/Core/Render/RenderCache.php b/core/lib/Drupal/Core/Render/RenderCache.php index 6cb15af8fc823919e20e4dcd3b45ef782164a420..c93079b507f6e8ad3621a1430aa8ab21575c62fb 100644 --- a/core/lib/Drupal/Core/Render/RenderCache.php +++ b/core/lib/Drupal/Core/Render/RenderCache.php @@ -59,16 +59,17 @@ public function __construct(RequestStack $request_stack, $cache_factory, CacheCo * {@inheritdoc} */ public function get(array $elements) { - // Form submissions rely on the form being built during the POST request, - // and render caching of forms prevents this from happening. - // @todo remove the isMethodCacheable() check when - // https://www.drupal.org/node/2367555 lands. - if (!$this->requestStack->getCurrentRequest()->isMethodCacheable() || !$this->isElementCacheable($elements)) { + if (!$this->isElementCacheable($elements)) { return FALSE; } $bin = isset($elements['#cache']['bin']) ? $elements['#cache']['bin'] : 'render'; if (($cache_bin = $this->cacheFactory->get($bin)) && $cache = $cache_bin->get($elements['#cache']['keys'], CacheableMetadata::createFromRenderArray($elements))) { + if (!$this->requestStack->getCurrentRequest()->isMethodCacheable()) { + if (!empty(array_filter($cache->tags, fn (string $tag) => str_starts_with($tag, 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:')))) { + return FALSE; + } + } return $cache->data; } return FALSE; @@ -78,10 +79,9 @@ public function get(array $elements) { * {@inheritdoc} */ public function set(array &$elements, array $pre_bubbling_elements) { - // Form submissions rely on the form being built during the POST request, - // and render caching of forms prevents this from happening. - // @todo remove the isMethodCacheable() check when - // https://www.drupal.org/node/2367555 lands. + // Avoid setting cache items on POST requests, this ensures that cache items + // with a very low hit rate won't enter the cache. All render elements + // except forms will still be retrieved from cache when available. if (!$this->requestStack->getCurrentRequest()->isMethodCacheable() || !$this->isElementCacheable($elements)) { return FALSE; } diff --git a/core/lib/Drupal/Core/Render/Renderer.php b/core/lib/Drupal/Core/Render/Renderer.php index 3ce49244de1f50c872172858f8f4d62f589120f9..a65c28537a184160fd4b5eebc0ae85795e8fdf9f 100644 --- a/core/lib/Drupal/Core/Render/Renderer.php +++ b/core/lib/Drupal/Core/Render/Renderer.php @@ -394,9 +394,11 @@ protected function doRender(&$elements, $is_root_call = FALSE) { } // If instructed to create a placeholder, and a #lazy_builder callback is // present (without such a callback, it would be impossible to replace the - // placeholder), replace the current element with a placeholder. - // @todo remove the isMethodCacheable() check when - // https://www.drupal.org/node/2367555 lands. + // placeholder), replace the current element with a placeholder. On + // uncacheable requests, always skip placeholdering - if a form is inside + // a placeholder, which is likely, we want to render it as soon as possible, + // so that form submission and redirection can take over before any more + // content is rendered. if (isset($elements['#create_placeholder']) && $elements['#create_placeholder'] === TRUE && $this->requestStack->getCurrentRequest()->isMethodCacheable()) { if (!isset($elements['#lazy_builder'])) { throw new \LogicException('When #create_placeholder is set, a #lazy_builder callback must be present as well.'); diff --git a/core/modules/big_pipe/src/Render/Placeholder/BigPipeStrategy.php b/core/modules/big_pipe/src/Render/Placeholder/BigPipeStrategy.php index 6219a1fddca6b475e0e49de24abaa87a03a0008f..6193b94a0a1b2b7f31a54183f202ab28ffacbdd4 100644 --- a/core/modules/big_pipe/src/Render/Placeholder/BigPipeStrategy.php +++ b/core/modules/big_pipe/src/Render/Placeholder/BigPipeStrategy.php @@ -108,7 +108,11 @@ public function __construct(SessionConfigurationInterface $session_configuration public function processPlaceholders(array $placeholders) { $request = $this->requestStack->getCurrentRequest(); - // @todo remove this check when https://www.drupal.org/node/2367555 lands. + // Prevent placeholders from being processed by BigPipe on uncacheable + // request methods. For example, a form rendered inside a placeholder will + // be rendered as soon as possible before any headers are sent, so that it + // can be detected, submitted, and redirected immediately. + // @todo https://www.drupal.org/node/2367555 if (!$request->isMethodCacheable()) { return []; } diff --git a/core/modules/block/tests/src/Functional/Views/DisplayBlockTest.php b/core/modules/block/tests/src/Functional/Views/DisplayBlockTest.php index 71f0a6d23b87579ec050f461e73835ed020fbd1a..4d74e8e494ee10d086e07c49187172a0d216a0f7 100644 --- a/core/modules/block/tests/src/Functional/Views/DisplayBlockTest.php +++ b/core/modules/block/tests/src/Functional/Views/DisplayBlockTest.php @@ -290,7 +290,7 @@ public function testBlockRendering() { $this->drupalGet(''); $this->assertSession()->elementNotExists('xpath', $block_title_xpath); - $this->assertCacheTags(array_merge($block->getCacheTags(), ['block_view', 'config:block_list', 'config:system.site', 'config:views.view.test_view_block', 'http_response', 'rendered'])); + $this->assertCacheTags(array_merge($block->getCacheTags(), ['block_view', 'config:block_list', 'config:system.site', 'config:views.view.test_view_block', 'http_response', 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form', 'rendered'])); } /** diff --git a/core/modules/block_content/tests/src/Functional/BlockContentCacheTagsTest.php b/core/modules/block_content/tests/src/Functional/BlockContentCacheTagsTest.php index 931241c56b92bd5f803280398ec52e3d137aaf01..5079d2abe40fcfd4ff9ddfe1569a8bf9889e8349 100644 --- a/core/modules/block_content/tests/src/Functional/BlockContentCacheTagsTest.php +++ b/core/modules/block_content/tests/src/Functional/BlockContentCacheTagsTest.php @@ -10,7 +10,6 @@ use Drupal\Core\Cache\CacheableMetadata; use Drupal\Core\Entity\EntityInterface; use Drupal\Tests\system\Functional\Entity\EntityCacheTagsTestBase; -use Symfony\Component\HttpFoundation\Request; /** * Tests the Content Block entity's cache tags. @@ -81,14 +80,7 @@ public function testBlock() { $build = $this->container->get('entity_type.manager')->getViewBuilder('block')->view($block, 'block'); // Render the block. - // @todo The request stack manipulation won't be necessary once - // https://www.drupal.org/node/2367555 is fixed and the - // corresponding $request->isMethodCacheable() checks are removed from - // Drupal\Core\Render\Renderer. - $request_stack = $this->container->get('request_stack'); - $request_stack->push(new Request()); $this->container->get('renderer')->renderRoot($build); - $request_stack->pop(); // Expected keys, contexts, and tags for the block. // @see \Drupal\block\BlockViewBuilder::viewMultiple() diff --git a/core/modules/comment/tests/src/Kernel/CommentDefaultFormatterCacheTagsTest.php b/core/modules/comment/tests/src/Kernel/CommentDefaultFormatterCacheTagsTest.php index a0dd05c23a8376b5167257afca5472abfa5a2525..c92e21ffc311121e8dd4cc86cc94de189796cd3d 100644 --- a/core/modules/comment/tests/src/Kernel/CommentDefaultFormatterCacheTagsTest.php +++ b/core/modules/comment/tests/src/Kernel/CommentDefaultFormatterCacheTagsTest.php @@ -84,6 +84,7 @@ public function testCacheTags() { $renderer->renderRoot($build); $expected_cache_tags = [ 'entity_test_view', + 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form', 'entity_test:' . $commented_entity->id(), 'config:core.entity_form_display.comment.comment.default', 'config:field.field.comment.comment.comment_body', @@ -131,6 +132,7 @@ public function testCacheTags() { 'comment:' . $comment->id(), 'config:filter.format.plain_text', 'user_view', + 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form', 'user:' . $user->id(), 'config:core.entity_form_display.comment.comment.default', 'config:field.field.comment.comment.comment_body', diff --git a/core/modules/node/node.module b/core/modules/node/node.module index fe660625d190438992a01ca036f95d6e57917a2c..508e4a76173fd44cd6b5d4165f64ea2a97f5c6cc 100644 --- a/core/modules/node/node.module +++ b/core/modules/node/node.module @@ -1036,9 +1036,8 @@ function node_query_node_access_alter(AlterableInterface $query) { // Bubble the 'user.node_grants:$op' cache context to the current render // context. - $request = \Drupal::requestStack()->getCurrentRequest(); $renderer = \Drupal::service('renderer'); - if ($request->isMethodCacheable() && $renderer->hasRenderContext()) { + if ($renderer->hasRenderContext()) { $build = ['#cache' => ['contexts' => ['user.node_grants:' . $op]]]; $renderer->render($build); } diff --git a/core/modules/page_cache/tests/src/Functional/PageCacheTagsIntegrationTest.php b/core/modules/page_cache/tests/src/Functional/PageCacheTagsIntegrationTest.php index 58dc8f75dc32dae3eef6794cc92d45d61ac54e02..fdc7fe194679c9688e586efbaa3cd3f25d44c93f 100644 --- a/core/modules/page_cache/tests/src/Functional/PageCacheTagsIntegrationTest.php +++ b/core/modules/page_cache/tests/src/Functional/PageCacheTagsIntegrationTest.php @@ -160,6 +160,7 @@ public function testPageCacheTags() { 'config:block.block.olivero_primary_admin_actions', 'config:block.block.olivero_page_title', 'node_view', + 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form', 'node:' . $node_1->id(), 'user:' . $author_1->id(), 'config:filter.format.basic_html', @@ -199,6 +200,7 @@ public function testPageCacheTags() { 'config:block.block.olivero_primary_admin_actions', 'config:block.block.olivero_page_title', 'node_view', + 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form', 'node:' . $node_2->id(), 'user:' . $author_2->id(), 'config:filter.format.full_html', diff --git a/core/modules/search/tests/src/Functional/SearchPageCacheTagsTest.php b/core/modules/search/tests/src/Functional/SearchPageCacheTagsTest.php index a127c8a435e29826856be57e3d1e49f31fea7f07..747d4a1741cdabaae85f28bfdbb15c272641db6c 100644 --- a/core/modules/search/tests/src/Functional/SearchPageCacheTagsTest.php +++ b/core/modules/search/tests/src/Functional/SearchPageCacheTagsTest.php @@ -185,6 +185,7 @@ public function testSearchTagsBubbling() { 'search_index', 'search_index:node_search', 'http_response', + 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form', 'rendered', 'node_list', ]; diff --git a/core/modules/shortcut/tests/src/Functional/ShortcutCacheTagsTest.php b/core/modules/shortcut/tests/src/Functional/ShortcutCacheTagsTest.php index 4cfc9e8b04fe457ac4f7694a571cc3ba6534df60..10e4923dfab43577f2353fcba316aa3a590d9a51 100644 --- a/core/modules/shortcut/tests/src/Functional/ShortcutCacheTagsTest.php +++ b/core/modules/shortcut/tests/src/Functional/ShortcutCacheTagsTest.php @@ -109,6 +109,7 @@ public function testToolbar() { 'config:shortcut.set.default', 'config:system.menu.admin', 'config:system.theme', + 'CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form', 'rendered', ]; $this->assertCacheTags($expected_cache_tags); diff --git a/core/profiles/standard/tests/src/FunctionalJavascript/StandardPerformanceTest.php b/core/profiles/standard/tests/src/FunctionalJavascript/StandardPerformanceTest.php index 19fe3c69227f58c53ec04f940b30bc4317c9f8cd..3463dd3f05418e5b9037303ff5f94f8d83fcc759 100644 --- a/core/profiles/standard/tests/src/FunctionalJavascript/StandardPerformanceTest.php +++ b/core/profiles/standard/tests/src/FunctionalJavascript/StandardPerformanceTest.php @@ -32,7 +32,11 @@ class StandardPerformanceTest extends PerformanceTestBase { */ protected function setUp(): void { parent::setUp(); - + // Create a node to be shown on the front page. + $this->drupalCreateNode([ + 'type' => 'article', + 'promote' => NodeInterface::PROMOTED, + ]); // Grant the anonymous user the permission to look at user profiles. user_role_grant_permissions('anonymous', ['access user profiles']); } @@ -41,11 +45,6 @@ protected function setUp(): void { * Tests performance for anonymous users. */ public function testAnonymous() { - // Create two nodes to be shown on the front page. - $this->drupalCreateNode([ - 'type' => 'article', - 'promote' => NodeInterface::PROMOTED, - ]); // Request a page that we're not otherwise explicitly testing to warm some // caches. $this->drupalGet('search'); @@ -260,7 +259,6 @@ public function testLoginBlock(): void { 'SELECT "name", "value" FROM "key_value" WHERE "name" IN ( "twig_extension_hash_prefix" ) AND "collection" = "state"', 'SELECT "name", "value" FROM "key_value" WHERE "name" IN ( "theme:stark" ) AND "collection" = "config.entity.key_store.block"', 'SELECT "config"."name" AS "name" FROM "config" "config" WHERE ("collection" = "") AND ("name" LIKE "search.page.%" ESCAPE ' . "'\\\\'" . ') ORDER BY "collection" ASC, "name" ASC', - 'SELECT "menu_tree"."id" AS "id" FROM "menu_tree" "menu_tree" WHERE ("menu_name" = "account") AND ("expanded" = 1) AND ("has_children" = 1) AND ("enabled" = 1) AND ("parent" IN ("")) AND ("id" NOT IN (""))', 'SELECT COUNT(*) AS "expression" FROM (SELECT 1 AS "expression" FROM "flood" "f" WHERE ("event" = "user.failed_login_ip") AND ("identifier" = "CLIENT_IP") AND ("timestamp" > "TIMESTAMP")) "subquery"', 'SELECT "base_table"."uid" AS "uid", "base_table"."uid" AS "base_table_uid" FROM "users" "base_table" INNER JOIN "users_field_data" "users_field_data" ON "users_field_data"."uid" = "base_table"."uid" WHERE ("users_field_data"."name" IN ("ACCOUNT_NAME")) AND ("users_field_data"."default_langcode" IN (1))', 'SELECT "base"."uid" AS "uid", "base"."uuid" AS "uuid", "base"."langcode" AS "langcode" FROM "users" "base" WHERE "base"."uid" IN (2)', @@ -286,12 +284,12 @@ public function testLoginBlock(): void { ]; $recorded_queries = $performance_data->getQueries(); $this->assertSame($expected_queries, $recorded_queries); - $this->assertSame(28, $performance_data->getQueryCount()); - $this->assertSame(85, $performance_data->getCacheGetCount()); + $this->assertSame(27, $performance_data->getQueryCount()); + $this->assertSame(108, $performance_data->getCacheGetCount()); $this->assertSame(1, $performance_data->getCacheSetCount()); $this->assertSame(1, $performance_data->getCacheDeleteCount()); $this->assertSame(1, $performance_data->getCacheTagChecksumCount()); - $this->assertSame(31, $performance_data->getCacheTagIsValidCount()); + $this->assertSame(44, $performance_data->getCacheTagIsValidCount()); $this->assertSame(0, $performance_data->getCacheTagInvalidationCount()); } diff --git a/core/tests/Drupal/KernelTests/Core/Render/Element/ActionsTest.php b/core/tests/Drupal/KernelTests/Core/Render/Element/ActionsTest.php index d26f7d5063349ce2080e04227400720a7201daa6..87da7a9f51f38fe7f3542156fd5070853cf7a2f2 100644 --- a/core/tests/Drupal/KernelTests/Core/Render/Element/ActionsTest.php +++ b/core/tests/Drupal/KernelTests/Core/Render/Element/ActionsTest.php @@ -65,7 +65,7 @@ public function testDropbuttonWithBubbleableMetadata() { $result = \Drupal::formBuilder()->getForm($this); \Drupal::service('renderer')->renderRoot($result); $this->assertEquals(['system/base', 'core/drupal.dropbutton'], $result['#attached']['library']); - $this->assertEquals(['foo'], $result['#cache']['tags']); + $this->assertEquals(['CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form', 'foo'], $result['#cache']['tags']); } } diff --git a/core/tests/Drupal/Tests/Core/Form/FormBuilderTest.php b/core/tests/Drupal/Tests/Core/Form/FormBuilderTest.php index 2bc128276dffbbfd5c40f5d6c031504184d4a9d5..f0b3425f5b86f92b8c2d7263bf052f17d02ec529 100644 --- a/core/tests/Drupal/Tests/Core/Form/FormBuilderTest.php +++ b/core/tests/Drupal/Tests/Core/Form/FormBuilderTest.php @@ -930,7 +930,7 @@ public function testFormTokenCacheability($token, $is_authenticated, $expected_f $form_state = new FormState(); $built_form = $this->formBuilder->buildForm($form_arg, $form_state); if (!isset($expected_form_cacheability) || ($method == 'get' && !is_string($token))) { - $this->assertFalse(isset($built_form['#cache'])); + $this->assertEquals($built_form['#cache'], ['tags' => ['CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form']]); } else { $this->assertTrue(isset($built_form['#cache'])); @@ -952,12 +952,12 @@ public function testFormTokenCacheability($token, $is_authenticated, $expected_f */ public static function providerTestFormTokenCacheability() { return [ - 'token:none,authenticated:true' => [NULL, TRUE, ['contexts' => ['user.roles:authenticated']], ['max-age' => 0], 'post'], - 'token:none,authenticated:false' => [NULL, FALSE, ['contexts' => ['user.roles:authenticated']], NULL, 'post'], + 'token:none,authenticated:true' => [NULL, TRUE, ['contexts' => ['user.roles:authenticated'], 'tags' => ['CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form']], ['max-age' => 0], 'post'], + 'token:none,authenticated:false' => [NULL, FALSE, ['contexts' => ['user.roles:authenticated'], 'tags' => ['CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form']], NULL, 'post'], 'token:false,authenticated:false' => [FALSE, FALSE, NULL, NULL, 'post'], 'token:false,authenticated:true' => [FALSE, TRUE, NULL, NULL, 'post'], - 'token:none,authenticated:false,method:get' => [NULL, FALSE, ['contexts' => ['user.roles:authenticated']], NULL, 'get'], - 'token:test_form_id,authenticated:false,method:get' => ['test_form_id', TRUE, ['contexts' => ['user.roles:authenticated']], ['max-age' => 0], 'get'], + 'token:none,authenticated:false,method:get' => [NULL, FALSE, ['contexts' => ['user.roles:authenticated'], 'tags' => ['CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form']], NULL, 'get'], + 'token:test_form_id,authenticated:false,method:get' => ['test_form_id', TRUE, ['contexts' => ['user.roles:authenticated'], 'tags' => ['CACHE_MISS_IF_UNCACHEABLE_HTTP_METHOD:form']], ['max-age' => 0], 'get'], ]; } diff --git a/core/tests/Drupal/Tests/Core/Render/RendererBubblingTest.php b/core/tests/Drupal/Tests/Core/Render/RendererBubblingTest.php index 514f7fe4a76283e0ba0e5109f711240471655c8c..d5362dc0daa8c479762a536977e2ce553159ae94 100644 --- a/core/tests/Drupal/Tests/Core/Render/RendererBubblingTest.php +++ b/core/tests/Drupal/Tests/Core/Render/RendererBubblingTest.php @@ -35,7 +35,7 @@ protected function setUp(): void { */ public function testBubblingWithoutPreRender() { $this->setUpRequest(); - $this->setupMemoryCache(); + $this->setUpMemoryCache(); $this->cacheContextsManager->expects($this->any()) ->method('convertTokensToKeys') @@ -135,7 +135,7 @@ public function testContextBubblingCustomCacheBin() { */ public function testContextBubblingEdgeCases(array $element, array $expected_top_level_contexts, $expected_cache_item) { $this->setUpRequest(); - $this->setupMemoryCache(); + $this->setUpMemoryCache(); $this->cacheContextsManager->expects($this->any()) ->method('convertTokensToKeys') ->willReturnArgument(0); @@ -316,7 +316,7 @@ public function testConditionalCacheContextBubblingSelfHealing() { $current_user_role = &$this->currentUserRole; $this->setUpRequest(); - $this->setupMemoryCache(); + $this->setUpMemoryCache(); $test_element = [ '#cache' => [ @@ -445,7 +445,7 @@ public function testConditionalCacheContextBubblingSelfHealing() { */ public function testBubblingWithPrerender($test_element) { $this->setUpRequest(); - $this->setupMemoryCache(); + $this->setUpMemoryCache(); // Mock the State service. $memory_state = new State(new KeyValueMemoryFactory()); @@ -528,7 +528,7 @@ public static function providerTestBubblingWithPrerender() { */ public function testOverWriteCacheKeys() { $this->setUpRequest(); - $this->setupMemoryCache(); + $this->setUpMemoryCache(); // Ensure a logic exception $data = [ diff --git a/core/tests/Drupal/Tests/Core/Render/RendererDebugTest.php b/core/tests/Drupal/Tests/Core/Render/RendererDebugTest.php index a433acd188d871f421cedcd59a3939cd6440c406..f8c506ac8bd026dae84d51b4fee58656dea10fcb 100644 --- a/core/tests/Drupal/Tests/Core/Render/RendererDebugTest.php +++ b/core/tests/Drupal/Tests/Core/Render/RendererDebugTest.php @@ -26,7 +26,7 @@ protected function setUp(): void { */ public function testDebugOutput() { $this->setUpRequest(); - $this->setupMemoryCache(); + $this->setUpMemoryCache(); $element = [ '#cache' => [ diff --git a/core/tests/Drupal/Tests/Core/Render/RendererPlaceholdersTest.php b/core/tests/Drupal/Tests/Core/Render/RendererPlaceholdersTest.php index 7f06ce447dbaa0f13931a896f97c891fc9e6203e..0ffb1b0dcc3d017bae2ce65c2c7a871db779b32f 100644 --- a/core/tests/Drupal/Tests/Core/Render/RendererPlaceholdersTest.php +++ b/core/tests/Drupal/Tests/Core/Render/RendererPlaceholdersTest.php @@ -564,7 +564,7 @@ protected function assertPlaceholderRenderCache($cache_keys, array $expected_dat */ public function testUncacheableParent(array $element, array $args, array $expected_placeholder_render_array, array|false $placeholder_cache_keys, array $bubbled_cache_contexts, array $bubbled_cache_tags, array $placeholder_expected_render_cache_array): void { if ($placeholder_cache_keys) { - $this->setupMemoryCache(); + $this->setUpMemoryCache(); } else { $this->setUpUnusedCache(); @@ -727,7 +727,7 @@ public function testCacheableParent(array $test_element, array $args, array $exp * @dataProvider providerPlaceholders */ public function testCacheableParentWithPostRequest(array $test_element, array $args): void { - $this->setUpUnusedCache(); + $this->setUpMemoryCache(); // Verify behavior when handling a non-GET request, e.g. a POST request: // also in that case, placeholders must be replaced. @@ -762,8 +762,13 @@ public function testCacheableParentWithPostRequest(array $test_element, array $a * * @dataProvider providerPlaceholders */ - public function testPlaceholderingDisabledForPostRequests(array $test_element, array $args): void { - $this->setUpUnusedCache(); + public function testPlaceholderingDisabledForPostRequests(array $test_element, array $args, array $expected_placeholder_render_array, array|false $placeholder_cache_keys): void { + if ($placeholder_cache_keys && !empty($test_element['placeholder']['#cache']['keys'])) { + $this->setUpMemoryCache(); + } + else { + $this->setUpUnusedCache(); + } $this->setUpRequest('POST'); $element = $test_element; diff --git a/core/tests/Drupal/Tests/Core/Render/RendererTest.php b/core/tests/Drupal/Tests/Core/Render/RendererTest.php index 9f613530203e9e5eb9a3b6a80c3b5da21855a751..9ee5ba13c50efd64c674eedbd3ea9b019b632413 100644 --- a/core/tests/Drupal/Tests/Core/Render/RendererTest.php +++ b/core/tests/Drupal/Tests/Core/Render/RendererTest.php @@ -832,7 +832,7 @@ public static function providerRenderCache() { */ public function testRenderCache($child_access, $expected_tags) { $this->setUpRequest(); - $this->setupMemoryCache(); + $this->setUpMemoryCache(); // Create an empty element. $test_element = [ @@ -882,7 +882,7 @@ public function testRenderCache($child_access, $expected_tags) { */ public function testRenderCacheMaxAge($max_age, $is_render_cached, $render_cache_item_expire) { $this->setUpRequest(); - $this->setupMemoryCache(); + $this->setUpMemoryCache(); $element = [ '#cache' => [ @@ -927,7 +927,7 @@ public static function providerTestRenderCacheMaxAge() { */ public function testRenderCacheProperties(array $expected_results) { $this->setUpRequest(); - $this->setupMemoryCache(); + $this->setUpMemoryCache(); $element = $original = [ '#cache' => [ diff --git a/core/tests/Drupal/Tests/Core/Render/RendererTestBase.php b/core/tests/Drupal/Tests/Core/Render/RendererTestBase.php index a7489a7704523bb576640e5fe37fea1ab9292a11..99797a37d4094c8bbe7290f762f23334106b8fc0 100644 --- a/core/tests/Drupal/Tests/Core/Render/RendererTestBase.php +++ b/core/tests/Drupal/Tests/Core/Render/RendererTestBase.php @@ -232,7 +232,7 @@ protected function setUpUnusedCache() { /** * Sets up a memory-based render cache back-end. */ - protected function setupMemoryCache() { + protected function setUpMemoryCache() { $this->memoryCache = $this->memoryCache ?: new VariationCache($this->requestStack, new MemoryBackend(new Time($this->requestStack)), $this->cacheContextsManager); $this->cacheFactory->expects($this->atLeastOnce())