View block breaking caching

Created on 12 February 2025, about 2 months ago

Problem/Motivation

We had this issue that we had not noticed for years of having a view block on some of our pages (or that's what we thought was the case). It would have 2 Contextual filters to match 2 fields in the content. Both are use custom views argument plugins that would get it's needed value from URL. So in the end, view would show content on very specific URL's. The block itself was configured for certain 1 type onf content type.

The thing is that there are hundreds of thousand of these nodes / pages and what happens if any node is saved in the system? node_list tag is invalidated, thus all of these thousands of pages are invalidated. Basically because content is saved all the time nothing really can stay in cache.

I wanted to ask if it wouldn't be possible not to bubble up this invalidation as the view knows it's not going to return anything as it has the contextual filters not returning anything?

Steps to reproduce

You could create 2 nodes in vanilla Drupal, create 1 view block to list those nodes and add the block after content. Then add Contextual filters on nid and get the parameter from query eg ?nid=2 .

When viewing node 1 ( /node/1 ) as anymous user you see that it's getting hit from Drupal cache afte first render. Now saving node 2 should not inlivadate node 1 page, but it does, even though view has no content as you have not defined ?nid in the node 1 url.

Proposed resolution

Don't allow view block to bubble up invalidation if contextual filters are not matching anything.

Remaining tasks

User interface changes

Introduced terminology

API changes

Data model changes

Release notes snippet

🐛 Bug report
Status

Active

Version

10.3

Component

views.module

Created by

🇪🇪Estonia hkirsman

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Production build 0.71.5 2024