- Issue created by @ihor_allin
- 🇳🇱Netherlands bbrala Netherlands
Great work, that will save quite some request/cpu time.
Any change you could add a line to the tests for that module? I think using:
$this->assertSession()->responseHeaderContains()
should be usefull for that to see if the cache has been hit if a second request is done. - 🇺🇦Ukraine ihor_allin Kyiv
It seems that the responses in these tests do not contain headers, just a raw JSON string.
- 🇳🇱Netherlands bbrala Netherlands
You need to use:
$this->assertSession()->responseHeaderEquals('X-Drupal-Cache', 'MISS'); // 1a. Check if second request is cached. $response = $this->drupalGet('/api/articles'); $this->assertSession()->responseHeaderEquals('X-Drupal-Cache', 'HIT');
Or something similar. When looking at the html output in files//simpletest/browser_output
array ( 'Date' => 'Sat, 18 Nov 2023 11:41:16 GMT', 'Server' => 'Apache/2.4.56 (Debian)', 'X-Powered-By' => 'PHP/8.1.25', 'X-Drupal-Assertion-0' => 'a%3A3%3A%7Bi%3A0%3BO%3A25%3A%22Drupal%5CCore%5CRender%5CMarkup%22%3A1%3A%7Bs%3A9%3A%22%00%2A%00string%22%3Bs%3A196%3A%22Since%20symfony%2Fserializer%206.3%3A%20%22Drupal%5Cjsonapi%5CNormalizer%5CImpostorFrom%5Cjsonapi_extras%5CFieldItemNormalizerImpostor%22%20should%20implement%20%22NormalizerInterface%3A%3AgetSupportedTypes%28%3Fstring%20%24format%29%3A%20array%22.%22%3B%7Di%3A1%3Bs%3A24%3A%22User%20deprecated%20function%22%3Bi%3A2%3Ba%3A3%3A%7Bs%3A8%3A%22function%22%3Bs%3A21%3A%22trigger_deprecation%28%29%22%3Bs%3A4%3A%22file%22%3Bs%3A61%3A%22%2Fgcl-builds%2Fvendor%2Fsymfony%2Fdeprecation-contracts%2Ffunction.php%22%3Bs%3A4%3A%22line%22%3Bi%3A25%3B%7D%7D', 'X-Drupal-Assertion-1' => 'a%3A3%3A%7Bi%3A0%3BO%3A25%3A%22Drupal%5CCore%5CRender%5CMarkup%22%3A1%3A%7Bs%3A9%3A%22%00%2A%00string%22%3Bs%3A205%3A%22Since%20symfony%2Fserializer%206.3%3A%20%22Drupal%5Cjsonapi%5CNormalizer%5CImpostorFrom%5Cjsonapi_extras%5CResourceIdentifierNormalizerImpostor%22%20should%20implement%20%22NormalizerInterface%3A%3AgetSupportedTypes%28%3Fstring%20%24format%29%3A%20array%22.%22%3B%7Di%3A1%3Bs%3A24%3A%22User%20deprecated%20function%22%3Bi%3A2%3Ba%3A3%3A%7Bs%3A8%3A%22function%22%3Bs%3A21%3A%22trigger_deprecation%28%29%22%3Bs%3A4%3A%22file%22%3Bs%3A61%3A%22%2Fgcl-builds%2Fvendor%2Fsymfony%2Fdeprecation-contracts%2Ffunction.php%22%3Bs%3A4%3A%22line%22%3Bi%3A25%3B%7D%7D', 'X-Drupal-Assertion-2' => 'a%3A3%3A%7Bi%3A0%3BO%3A25%3A%22Drupal%5CCore%5CRender%5CMarkup%22%3A1%3A%7Bs%3A9%3A%22%00%2A%00string%22%3Bs%3A201%3A%22Since%20symfony%2Fserializer%206.3%3A%20%22Drupal%5Cjsonapi%5CNormalizer%5CImpostorFrom%5Cjsonapi_extras%5CResourceObjectNormalizerImpostor%22%20should%20implement%20%22NormalizerInterface%3A%3AgetSupportedTypes%28%3Fstring%20%24format%29%3A%20array%22.%22%3B%7Di%3A1%3Bs%3A24%3A%22User%20deprecated%20function%22%3Bi%3A2%3Ba%3A3%3A%7Bs%3A8%3A%22function%22%3Bs%3A21%3A%22trigger_deprecation%28%29%22%3Bs%3A4%3A%22file%22%3Bs%3A61%3A%22%2Fgcl-builds%2Fvendor%2Fsymfony%2Fdeprecation-contracts%2Ffunction.php%22%3Bs%3A4%3A%22line%22%3Bi%3A25%3B%7D%7D', 'X-Drupal-Assertion-3' => 'a%3A3%3A%7Bi%3A0%3BO%3A25%3A%22Drupal%5CCore%5CRender%5CMarkup%22%3A1%3A%7Bs%3A9%3A%22%00%2A%00string%22%3Bs%3A202%3A%22Since%20symfony%2Fserializer%206.3%3A%20%22Drupal%5Cjsonapi%5CNormalizer%5CImpostorFrom%5Cjsonapi_extras%5CContentEntityDenormalizerImpostor%22%20should%20implement%20%22NormalizerInterface%3A%3AgetSupportedTypes%28%3Fstring%20%24format%29%3A%20array%22.%22%3B%7Di%3A1%3Bs%3A24%3A%22User%20deprecated%20function%22%3Bi%3A2%3Ba%3A3%3A%7Bs%3A8%3A%22function%22%3Bs%3A21%3A%22trigger_deprecation%28%29%22%3Bs%3A4%3A%22file%22%3Bs%3A61%3A%22%2Fgcl-builds%2Fvendor%2Fsymfony%2Fdeprecation-contracts%2Ffunction.php%22%3Bs%3A4%3A%22line%22%3Bi%3A25%3B%7D%7D', 'X-Drupal-Assertion-4' => 'a%3A3%3A%7Bi%3A0%3BO%3A25%3A%22Drupal%5CCore%5CRender%5CMarkup%22%3A1%3A%7Bs%3A9%3A%22%00%2A%00string%22%3Bs%3A201%3A%22Since%20symfony%2Fserializer%206.3%3A%20%22Drupal%5Cjsonapi%5CNormalizer%5CImpostorFrom%5Cjsonapi_extras%5CConfigEntityDenormalizerImpostor%22%20should%20implement%20%22NormalizerInterface%3A%3AgetSupportedTypes%28%3Fstring%20%24format%29%3A%20array%22.%22%3B%7Di%3A1%3Bs%3A24%3A%22User%20deprecated%20function%22%3Bi%3A2%3Ba%3A3%3A%7Bs%3A8%3A%22function%22%3Bs%3A21%3A%22trigger_deprecation%28%29%22%3Bs%3A4%3A%22file%22%3Bs%3A61%3A%22%2Fgcl-builds%2Fvendor%2Fsymfony%2Fdeprecation-contracts%2Ffunction.php%22%3Bs%3A4%3A%22line%22%3Bi%3A25%3B%7D%7D', 'Cache-Control' => 'must-revalidate, no-cache, private', 'X-Drupal-Dynamic-Cache' => 'MISS', 'Content-language' => 'en', 'X-Content-Type-Options' => 'nosniff', 'X-Frame-Options' => 'SAMEORIGIN', 'X-Drupal-Cache-Tags' => 'config:filter.format.plain_text config:jsonapi_extras.settings config:jsonapi_resource_config_list config:user.role.anonymous http_response node:1 node:2 node_list taxonomy_term:2 taxonomy_term:3 taxonomy_term:4 taxonomy_term:5', 'X-Drupal-Cache-Contexts' => 'languages:language_interface theme url.query_args:fields url.query_args:filter url.query_args:include url.query_args:page url.query_args:resourceVersion url.query_args:sort url.site user.permissions', 'X-Drupal-Cache-Max-Age' => '-1 (Permanent)', 'Expires' => 'Sun, 19 Nov 1978 05:00:00 GMT', 'X-Generator' => 'Drupal 10 (https://www.drupal.org)', 'X-Drupal-Cache' => 'MISS', 'Transfer-Encoding' => 'chunked', 'Content-Type' => 'application/vnd.api+json', )
I see cache info. Locally i was not sure how to reproduce the error, i got a hit on the second call.
- 🇺🇦Ukraine ihor_allin Kyiv
@bbrala, thank you for the clear explanation. Updating the patch with the corresponding tests. Passed successfully on my local env
- last update
about 1 year ago 17 pass - last update
about 1 year ago 14 pass, 1 fail - 🇳🇱Netherlands bbrala Netherlands
Hmm, gitlab is weird.
But when i run those tests locally, when i do only the test (which should fail right?) then the test is still green. So that test doesn't proove the faulty caching...
- 🇺🇦Ukraine ihor_allin Kyiv
@bbrala do you have default includes added when you test it locally?
- last update
about 1 year ago 17 pass - last update
about 1 year ago Patch Failed to Apply - last update
about 1 year ago Patch Failed to Apply - last update
about 1 year ago 17 pass - last update
about 1 year ago 17 pass - 🇺🇦Ukraine ihor_allin Kyiv
For some reason, locally, I have also passed tests by adding a cache tag check: $this->assertSession()->responseHeaderEquals('X-Drupal-Cache', 'HIT') after the second request to '/api/articles'. However, at the same time, when I check it by visiting the JSON API route with the resource with default includes, I always receive an uncached response.
- 🇺🇦Ukraine ihor_allin Kyiv
Fixed 500 error for the resources without default includes
- 🇺🇦Ukraine _tarik_ Lutsk
Thanks ihor_allin. The patch in comment #16 works for me.
- 🇮🇳India Ankush_03 Gurgaon, India 🇮🇳
Hey @bbrala,
Any update on the above fix ??
- last update
10 months ago 11 pass, 4 fail - Status changed to Needs review
10 months ago 8:33am 25 March 2024 - last update
10 months ago Patch Failed to Apply - last update
10 months ago 8 pass, 5 fail - last update
10 months ago 8 pass, 5 fail - last update
10 months ago Patch Failed to Apply - last update
10 months ago Patch Failed to Apply - last update
10 months ago 11 pass, 4 fail - last update
10 months ago 16 pass, 2 fail The last submitted patch, 2: 3402388-default-includes-caching-fix.patch, failed testing. View results →
- codesniffer_fixes.patch Interdiff of automated coding standards fixes only.The last submitted patch, 7: 3402388-default-includes-caching-fix-7.patch, failed testing. View results →
- codesniffer_fixes.patch Interdiff of automated coding standards fixes only.- last update
10 months ago 17 pass - 🇮🇳India gaurav_manerkar Vasco Da Gama, Goa
- 🇺🇦Ukraine _tarik_ Lutsk
I have found an issue with response caching with this patch.
The isDefaultIncludes method checks only if the request contains included parameters from the jsonapi_extras configuration. So, it can cause problems when the one cached response is used for different includes params.Say, you have an endpoint for an article that uses 3 taxonomy fields (field_tag, field_type, field_category).
The jsonapi_extras is configured to include by default the field_type field. Then if you send the first request with ?include=field_category this response will be cached and applied to the response without the include param or for ?include=field_tag.So, instead of checking if the request uses default includes we need to check if the request uses ONLY default includes.
- last update
9 months ago 17 pass - last update
9 months ago 17 pass - 🇺🇦Ukraine _tarik_ Lutsk
The diff for PR to avoid adding numerous commits to the composer.json.
- last update
9 months ago 17 pass - last update
9 months ago 17 pass - 🇺🇦Ukraine _tarik_ Lutsk
I realized that made a mistake in my previous commit. Here is the correct version of the patch
- Status changed to Fixed
8 months ago 2:03pm 24 May 2024 - 🇳🇱Netherlands bbrala Netherlands
Ty for taking the time here to fix this up. Changes seem to work as promised <3
- last update
8 months ago 17 pass Automatically closed - issue fixed for 2 weeks with no activity.