Pages with default includes are not cached

Created on 17 November 2023, about 1 year ago
Updated 7 June 2024, 8 months ago

Problem/Motivation

All pages under the 'jsonapi/*' routes that contain nodes with default includes are not cached. This is because the default include is added dynamically in the 'Drupal\jsonapi_defaults\Controller\EntityResource' dynamic route controller service. The 'getIncludes' method executes after the cache is retrieved from the database, resulting in the cache cid being generated without default includes during the cache retrieval process.

On the other hand, 'getIncludes' executes before the cache is set to the database, and during this phase, the cache cid is generated using default includes added to the request. Consequently, we have a cache stored in the database using the default includes context. However, Drupal always attempts to retrieve the cache with a different cid, one that was generated without the default includes context.

As a result, the only way to obtain a cached response is by adding default includes explicitly as get parameters. This is because the cache stored in the database is under a cid generated using these includes added dynamically as default includes. Consequently, we consistently receive an uncached response for pages with default includes.

Steps to reproduce

  1. Add default includes to any content type
  2. Create a page of this content type
  3. Visit this page using the jsonapi/* route, for instance, jsonapi/node/article/324f078e-e3a0-4e3a-b902-0a76f072bdd2
  4. Check the cache header in the response
  5. Reload the page
  6. Check the cache header in the response

Actual result: After the first visit to the page, the cache status is marked as "MISS" and after reloading the page, the cache status remains "MISS."

Expected result: Following the initial visit to the page, the cache status should be "MISS," but after reloading the page, the cache status is expected to change to "HIT."

Proposed resolution

Override the core QueryArgsCacheContext (cache_context.url.query_args) service to disregard all default includes arguments. Consequently, for all requests to resources with default includes, the cache will be stored under the cid generated without using the default includes context. This modification enables us to obtain cached responses for all resources with default includes.

🐛 Bug report
Status

Fixed

Version

3.0

Component

Code

Created by

🇺🇦Ukraine ihor_allin Kyiv

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

Merge Requests

Comments & Activities

  • Pipeline finished with Skipped
    over 1 year ago
    #16330
  • 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

  • Merge request !39Test caching → (Open) created by bbrala
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.1.4 + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    17 pass
  • Merge request !40Resolve #3402388 "Pages with default" → (Merged) created by bbrala
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.1.4 + Environment: PHP 8.1 & MySQL 5.7
    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?

  • 🇺🇦Ukraine ihor_allin Kyiv

    Fixed bug with variable name

  • Open in Jenkins → Open on Drupal.org →
    Core: 10.1.4 + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    17 pass
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.1.4 + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    Patch Failed to Apply
  • Open in Jenkins → Open on Drupal.org →
    Core: 9.5.x + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    Patch Failed to Apply
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.1.4 + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    17 pass
  • Pipeline finished with Success
    about 1 year ago
    Total: 215s
    #53428
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.1.4 + Environment: PHP 8.1 & MySQL 5.7
    last update about 1 year ago
    17 pass
  • Pipeline finished with Success
    about 1 year ago
    Total: 207s
    #53439
  • 🇺🇦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

    Update patch with minor code styles fixes

  • 🇺🇦Ukraine ihor_allin Kyiv

    Fixed 500 error for the resources without default includes

  • Pipeline finished with Success
    about 1 year ago
    Total: 258s
    #56199
  • Pipeline finished with Failed
    about 1 year ago
    Total: 72s
    #63905
  • Pipeline finished with Success
    about 1 year ago
    Total: 189s
    #77904
  • Pipeline finished with Success
    about 1 year ago
    Total: 243s
    #78132
  • Pipeline finished with Failed
    about 1 year ago
    Total: 167s
    #78138
  • Pipeline finished with Skipped
    about 1 year ago
    #78848
  • Pipeline finished with Success
    about 1 year ago
    Total: 190s
    #80112
  • Pipeline finished with Success
    about 1 year ago
    Total: 162s
    #80119
  • Pipeline finished with Success
    12 months ago
    Total: 521s
    #83871
  • Pipeline finished with Success
    12 months ago
    Total: 276s
    #87599
  • Pipeline finished with Success
    12 months ago
    #91049
  • Pipeline finished with Success
    11 months ago
    Total: 210s
    #97046
  • Pipeline finished with Success
    11 months ago
    Total: 145s
    #97062
  • Pipeline finished with Failed
    11 months ago
    Total: 153s
    #98409
  • Pipeline finished with Failed
    11 months ago
    Total: 311s
    #101809
  • Pipeline finished with Success
    11 months ago
    #103886
  • Pipeline finished with Success
    11 months ago
    Total: 310s
    #103898
  • 🇺🇦Ukraine _tarik_ Lutsk

    Thanks ihor_allin. The patch in comment #16 works for me.

  • Pipeline finished with Success
    11 months ago
    Total: 313s
    #111082
  • 🇮🇳India Ankush_03 Gurgaon, India 🇮🇳

    Hey @bbrala,

    Any update on the above fix ??

  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 10 months ago
    11 pass, 4 fail
  • 🇮🇳India Ankush_03 Gurgaon, India 🇮🇳
  • Pipeline finished with Success
    10 months ago
    #123283
  • Pipeline finished with Success
    10 months ago
    Total: 160s
    #125507
  • Pipeline finished with Success
    10 months ago
    Total: 169s
    #128370
  • Status changed to Needs review 10 months ago
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 10 months ago
    Patch Failed to Apply
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 10 months ago
    8 pass, 5 fail
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 10 months ago
    8 pass, 5 fail
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 10 months ago
    Patch Failed to Apply
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 10 months ago
    Patch Failed to Apply
  • 🇮🇳India gaurav_manerkar Vasco Da Gama, Goa
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 10 months ago
    11 pass, 4 fail
  • Pipeline finished with Failed
    10 months ago
    #128396
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    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.

  • Pipeline finished with Failed
    10 months ago
    Total: 229s
    #128405
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 10 months ago
    17 pass
  • Pipeline finished with Success
    10 months ago
    Total: 231s
    #128412
  • Pipeline finished with Success
    10 months ago
    Total: 153s
    #129435
  • Pipeline finished with Success
    10 months ago
    Total: 294s
    #133474
  • 🇩🇪Germany Anybody Porta Westfalica
  • 🇺🇦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.

  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 9 months ago
    17 pass
  • Pipeline finished with Success
    9 months ago
    Total: 258s
    #160801
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 9 months ago
    17 pass
  • 🇺🇦Ukraine _tarik_ Lutsk

    The diff for PR to avoid adding numerous commits to the composer.json.

  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 9 months ago
    17 pass
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    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

  • Pipeline finished with Success
    9 months ago
    Total: 215s
    #163439
  • Pipeline finished with Success
    8 months ago
    Total: 155s
    #173450
  • Pipeline finished with Failed
    8 months ago
    Total: 232s
    #176288
  • Pipeline finished with Failed
    8 months ago
    Total: 212s
    #176293
  • Status changed to Fixed 8 months ago
  • 🇳🇱Netherlands bbrala Netherlands

    Ty for taking the time here to fix this up. Changes seem to work as promised <3

  • Pipeline finished with Skipped
    8 months ago
    #181349
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 8 months ago
    17 pass
    • bbrala committed 373f0114 on 8.x-3.x
      Issue #3402388 by ihor_allin, bbrala, _tarik_, gaurav_manerkar,...
  • 🇳🇱Netherlands bbrala Netherlands
  • Pipeline finished with Canceled
    8 months ago
    Total: 637s
    #183477
  • Pipeline finished with Success
    8 months ago
    Total: 172s
    #186690
  • Pipeline finished with Success
    8 months ago
    Total: 241s
    #189608
  • Pipeline finished with Success
    8 months ago
    Total: 148s
    #189722
  • Automatically closed - issue fixed for 2 weeks with no activity.

  • Pipeline finished with Failed
    8 months ago
    Total: 212s
    #194681
  • Pipeline finished with Success
    7 months ago
    #203509
  • Pipeline finished with Failed
    7 months ago
    Total: 342s
    #203556
  • Pipeline finished with Success
    7 months ago
    Total: 296s
    #203584
  • Pipeline finished with Skipped
    7 months ago
    #212583
  • Pipeline finished with Skipped
    7 months ago
    #217965
  • Pipeline finished with Skipped
    6 months ago
    #221440
  • Pipeline finished with Failed
    6 months ago
    Total: 143s
    #223958
  • Pipeline finished with Failed
    6 months ago
    Total: 268s
    #231788
  • Pipeline finished with Success
    6 months ago
    Total: 204s
    #232011
  • Pipeline finished with Success
    6 months ago
    Total: 216s
    #232353
  • Pipeline finished with Success
    6 months ago
    Total: 204s
    #232858
  • Pipeline finished with Success
    6 months ago
    Total: 81s
    #235300
  • Pipeline finished with Canceled
    6 months ago
    Total: 129s
    #237035
  • Pipeline finished with Canceled
    6 months ago
    Total: 123s
    #241623
  • Pipeline finished with Success
    6 months ago
    Total: 712s
    #245934
  • Pipeline finished with Success
    5 months ago
    #251930
  • Pipeline finished with Success
    5 months ago
    Total: 257s
    #255158
  • Pipeline finished with Success
    5 months ago
    Total: 168s
    #256888
  • Pipeline finished with Failed
    5 months ago
    Total: 357s
    #258381
  • Pipeline finished with Success
    5 months ago
    Total: 263s
    #258403
  • Pipeline finished with Failed
    5 months ago
    Total: 174s
    #261977
  • Pipeline finished with Failed
    5 months ago
    Total: 347s
    #261993
  • Pipeline finished with Success
    5 months ago
    Total: 263s
    #265464
  • Pipeline finished with Success
    5 months ago
    Total: 151s
    #270059
  • Pipeline finished with Success
    5 months ago
    Total: 183s
    #275501
  • Pipeline finished with Success
    5 months ago
    Total: 343s
    #276102
  • Pipeline finished with Success
    4 months ago
    Total: 252s
    #276442
  • Pipeline finished with Success
    4 months ago
    Total: 231s
    #279226
  • Pipeline finished with Canceled
    4 months ago
    Total: 74s
    #279300
  • Pipeline finished with Success
    4 months ago
    Total: 248s
    #279302
  • Pipeline finished with Success
    4 months ago
    Total: 194s
    #280526
  • Pipeline finished with Success
    4 months ago
    Total: 322s
    #283116
  • Pipeline finished with Success
    4 months ago
    Total: 135s
    #283120
  • Pipeline finished with Success
    4 months ago
    Total: 233s
    #283230
  • Pipeline finished with Failed
    4 months ago
    Total: 680s
    #285589
  • Pipeline finished with Canceled
    4 months ago
    Total: 270s
    #285804
  • Pipeline finished with Success
    4 months ago
    Total: 192s
    #286099
  • Pipeline finished with Failed
    4 months ago
    Total: 1047s
    #292003
  • Pipeline finished with Success
    4 months ago
    Total: 160s
    #293267
  • Pipeline finished with Success
    4 months ago
    Total: 307s
    #295025
  • Pipeline finished with Success
    4 months ago
    Total: 229s
    #297535
  • Pipeline finished with Canceled
    4 months ago
    Total: 346s
    #297538
  • Pipeline finished with Success
    3 months ago
    Total: 157s
    #312413
  • Pipeline finished with Success
    3 months ago
    Total: 150s
    #313497
  • Pipeline finished with Success
    3 months ago
    Total: 151s
    #321448
  • Pipeline finished with Success
    3 months ago
    Total: 197s
    #321589
  • Pipeline finished with Success
    3 months ago
    Total: 677s
    #327592
  • Pipeline finished with Canceled
    3 months ago
    Total: 305s
    #327613
  • Pipeline finished with Failed
    3 months ago
    Total: 222s
    #329321
  • Pipeline finished with Failed
    3 months ago
    Total: 225s
    #329332
  • Pipeline finished with Failed
    3 months ago
    Total: 195s
    #329496
  • Pipeline finished with Canceled
    3 months ago
    Total: 119s
    #329500
  • Pipeline finished with Failed
    about 2 months ago
    Total: 167s
    #349972
  • Pipeline finished with Failed
    about 2 months ago
    Total: 560s
    #352174
  • Pipeline finished with Success
    about 2 months ago
    Total: 154s
    #352286
  • Pipeline finished with Success
    about 2 months ago
    Total: 505s
    #352407
  • Pipeline finished with Success
    about 2 months ago
    Total: 2019s
    #352440
  • Pipeline finished with Skipped
    about 2 months ago
    #358265
  • Pipeline finished with Failed
    about 2 months ago
    Total: 130s
    #360963
  • Pipeline finished with Failed
    about 1 month ago
    Total: 219s
    #363805
  • Pipeline finished with Failed
    about 1 month ago
    Total: 148s
    #370202
  • Pipeline finished with Failed
    21 days ago
    Total: 232s
    #381788
  • Pipeline finished with Failed
    21 days ago
    Total: 166s
    #381812
  • Pipeline finished with Canceled
    21 days ago
    Total: 127s
    #381910
  • Pipeline finished with Success
    21 days ago
    Total: 158s
    #381918
  • Pipeline finished with Failed
    11 days ago
    Total: 151s
    #390625
  • Pipeline finished with Failed
    10 days ago
    Total: 181s
    #391676
  • Pipeline finished with Success
    10 days ago
    Total: 293s
    #391995
  • Pipeline finished with Success
    6 days ago
    Total: 171s
    #394915
Production build 0.71.5 2024