Update constructor when #3100732: Allow specifying metadata on JSON:API objects lands

Created on 2 June 2024, 11 months ago

Problem/Motivation

After upgrading from 3.24 to 3.25, when I try to run drush updatedb or drush cr, I get the following error:

 [error]  TypeError: Drupal\jsonapi_defaults\Controller\EntityResource::__construct(): Argument #12 ($jsonapi_defaults) must be of type Drupal\jsonapi_defaults\JsonapiDefaultsInterface, Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher given in Drupal\jsonapi_defaults\Controller\EntityResource->__construct() (line 75 of /var/www/html/web/modules/contrib/jsonapi_extras/modules/jsonapi_defaults/src/Controller/EntityResource.php) #0 [internal function]: Drupal\jsonapi_defaults\Controller\EntityResource->__construct()

Reverting to 3.24 clears the error. By moving backwards one commit at a time in the git history, I traced the breakage to 🐛 Pages with default includes are not cached Fixed .

Drupal 10.2.6, PHP 8.3.

📌 Task
Status

Postponed

Version

3.0

Component

Code

Created by

🇯🇵Japan ptmkenny

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

Merge Requests

Comments & Activities

  • Issue created by @ptmkenny
  • 🇯🇵Japan ptmkenny

    Full stacktrace:

    Fatal error: Uncaught TypeError: Drupal\jsonapi_defaults\Controller\EntityResource::__construct(): Argument #12 ($jsonapi_defaults) must be of type Drupal\jsonapi_defaults\JsonapiDefaultsInterface, Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher given, called in /var/www/html/web/core/lib/Drupal/Component/DependencyInjection/Container.php on line 259 and defined in /var/www/html/web/modules/jsonapi_extras/modules/jsonapi_defaults/src/Controller/EntityResource.php:75
    Stack trace:
    #0 /var/www/html/web/core/lib/Drupal/Component/DependencyInjection/Container.php(259): Drupal\jsonapi_defaults\Controller\EntityResource->__construct()
    #1 /var/www/html/web/core/lib/Drupal/Component/DependencyInjection/Container.php(177): Drupal\Component\DependencyInjection\Container->createService()
    #2 /var/www/html/web/core/lib/Drupal/Core/DependencyInjection/ClassResolver.php(20): Drupal\Component\DependencyInjection\Container->get()
    #3 /var/www/html/web/core/lib/Drupal/Core/Entity/EntityResolverManager.php(106): Drupal\Core\DependencyInjection\ClassResolver->getInstanceFromDefinition()
    #4 /var/www/html/web/core/lib/Drupal/Core/Entity/EntityResolverManager.php(219): Drupal\Core\Entity\EntityResolverManager->getControllerClass()
    #5 /var/www/html/web/core/lib/Drupal/Core/EventSubscriber/EntityRouteAlterSubscriber.php(48): Drupal\Core\Entity\EntityResolverManager->setRouteOptions()
    #6 [internal function]: Drupal\Core\EventSubscriber\EntityRouteAlterSubscriber->onRoutingRouteAlterSetType()
    #7 /var/www/html/web/core/lib/Drupal/Component/EventDispatcher/ContainerAwareEventDispatcher.php(111): call_user_func()
    #8 /var/www/html/web/core/lib/Drupal/Core/Routing/RouteBuilder.php(189): Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher->dispatch()
    #9 /var/www/html/web/core/lib/Drupal/Core/ProxyClass/Routing/RouteBuilder.php(83): Drupal\Core\Routing\RouteBuilder->rebuild()
    #10 /var/www/html/web/core/includes/common.inc(485): Drupal\Core\ProxyClass\Routing\RouteBuilder->rebuild()
    #11 /var/www/html/web/core/includes/utility.inc(41): drupal_flush_all_caches()
    #12 /var/www/html/vendor/drush/drush/src/Commands/core/CacheRebuildCommands.php(70): drupal_rebuild()
    #13 [internal function]: Drush\Commands\core\CacheRebuildCommands->rebuild()
    #14 /var/www/html/vendor/consolidation/annotated-command/src/CommandProcessor.php(276): call_user_func_array()
    #15 /var/www/html/vendor/consolidation/annotated-command/src/CommandProcessor.php(212): Consolidation\AnnotatedCommand\CommandProcessor->runCommandCallback()
    #16 /var/www/html/vendor/consolidation/annotated-command/src/CommandProcessor.php(175): Consolidation\AnnotatedCommand\CommandProcessor->validateRunAndAlter()
    #17 /var/www/html/vendor/consolidation/annotated-command/src/AnnotatedCommand.php(387): Consolidation\AnnotatedCommand\CommandProcessor->process()
    #18 /var/www/html/vendor/symfony/console/Command/Command.php(326): Consolidation\AnnotatedCommand\AnnotatedCommand->execute()
    #19 /var/www/html/vendor/symfony/console/Application.php(1096): Symfony\Component\Console\Command\Command->run()
    #20 /var/www/html/vendor/symfony/console/Application.php(324): Symfony\Component\Console\Application->doRunCommand()
    #21 /var/www/html/vendor/symfony/console/Application.php(175): Symfony\Component\Console\Application->doRun()
    #22 /var/www/html/vendor/drush/drush/src/Runtime/Runtime.php(110): Symfony\Component\Console\Application->run()
    #23 /var/www/html/vendor/drush/drush/src/Runtime/Runtime.php(40): Drush\Runtime\Runtime->doRun()
    #24 /var/www/html/vendor/drush/drush/drush.php(139): Drush\Runtime\Runtime->run()
    #25 /var/www/html/vendor/drush/drush/drush(4): require('...')
    #26 /var/www/html/vendor/bin/drush(119): include('...')
    #27 {main}
      thrown in /var/www/html/web/modules/jsonapi_extras/modules/jsonapi_defaults/src/Controller/EntityResource.php on line 75
     [warning] Drush command terminated abnormally.
    
  • Merge request !51inject event_dispatcher → (Open) created by ptmkenny
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    last update 11 months ago
    17 pass, 2 fail
  • Status changed to Needs review 11 months ago
  • 🇯🇵Japan ptmkenny

    The eventDispatcher never got injected, but it is provided by core, so then in construct() all the arguments get out of order, breaking the site. This MR injects the eventDispatcher so that the parent constructor can be called properly.

  • Pipeline finished with Failed
    11 months ago
    #189168
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    33:47
    32:02
    Running
  • Open in Jenkins → Open on Drupal.org →
    Core: 10.2.1 + Environment: PHP 8.1 & MySQL 5.7
    29:59
    28:03
    Running
  • Pipeline finished with Canceled
    11 months ago
    Total: 205s
    #189183
  • Status changed to Postponed 11 months ago
  • 🇯🇵Japan ptmkenny

    So this issue was caused by me having applied the MR in Allow specifying `meta` data on JSON:API objects Needs work . When this issue eventually gets committed to core, the code will need to be updated, so I'm marking postponed for now. But feel free to close if you would rather handle this once the commit actually happens.

  • Pipeline finished with Failed
    11 months ago
    Total: 249s
    #189190
  • Pipeline finished with Success
    10 months ago
    Total: 356s
    #196967
  • Pipeline finished with Failed
    10 months ago
    Total: 206s
    #197540
  • Pipeline finished with Failed
    10 months ago
    Total: 270s
    #197543
  • Pipeline finished with Success
    10 months ago
    Total: 281s
    #197591
  • Pipeline finished with Success
    10 months ago
    Total: 1133s
    #197657
  • Pipeline finished with Success
    10 months ago
    Total: 204s
    #197669
  • Pipeline finished with Failed
    10 months ago
    Total: 300s
    #198255
  • Pipeline finished with Failed
    10 months ago
    Total: 298s
    #199186
  • Pipeline finished with Failed
    10 months ago
    Total: 306s
    #199206
  • Pipeline finished with Failed
    10 months ago
    Total: 301s
    #199239
  • Pipeline finished with Failed
    10 months ago
    Total: 309s
    #199253
  • Pipeline finished with Failed
    10 months ago
    Total: 292s
    #199272
  • Pipeline finished with Success
    10 months ago
    Total: 151s
    #200133
  • Pipeline finished with Success
    10 months ago
    Total: 144s
    #200846
  • Pipeline finished with Skipped
    10 months ago
    #204135
  • Pipeline finished with Failed
    10 months ago
    Total: 198s
    #204786
  • Pipeline finished with Success
    10 months ago
    Total: 312s
    #204981
  • Pipeline finished with Success
    10 months ago
    Total: 276s
    #205444
  • Pipeline finished with Failed
    10 months ago
    Total: 206s
    #205461
  • Pipeline finished with Skipped
    10 months ago
    #211735
  • Pipeline finished with Success
    10 months ago
    Total: 217s
    #213908
  • Pipeline finished with Failed
    9 months ago
    Total: 329s
    #215998
  • Pipeline finished with Failed
    9 months ago
    #216508
  • Pipeline finished with Failed
    9 months ago
    Total: 218s
    #220045
  • Pipeline finished with Failed
    9 months ago
    Total: 263s
    #220058
  • Pipeline finished with Failed
    9 months ago
    Total: 241s
    #220077
  • Pipeline finished with Success
    9 months ago
    Total: 353s
    #220132
  • Pipeline finished with Success
    9 months ago
    #220265
  • Pipeline finished with Success
    9 months ago
    Total: 203s
    #221230
  • Pipeline finished with Skipped
    9 months ago
    #225649
  • Pipeline finished with Failed
    9 months ago
    Total: 392s
    #233781
  • Pipeline finished with Success
    9 months ago
    Total: 407s
    #235552
  • Pipeline finished with Failed
    9 months ago
    Total: 151s
    #242124
  • Pipeline finished with Skipped
    8 months ago
    #247021
  • Pipeline finished with Skipped
    8 months ago
    #255207
  • Pipeline finished with Success
    8 months ago
    #255671
  • Pipeline finished with Failed
    8 months ago
    Total: 1708s
    #263399
  • Pipeline finished with Failed
    7 months ago
    Total: 187s
    #272588
  • Pipeline finished with Failed
    7 months ago
    Total: 196s
    #272593
  • Pipeline finished with Success
    7 months ago
    Total: 174s
    #272617
  • Pipeline finished with Success
    7 months ago
    Total: 161s
    #272627
  • Pipeline finished with Failed
    7 months ago
    Total: 158s
    #272657
  • Pipeline finished with Failed
    7 months ago
    Total: 140s
    #273436
  • Pipeline finished with Failed
    7 months ago
    Total: 295s
    #276576
  • Pipeline finished with Failed
    7 months ago
    Total: 206s
    #284949
  • Pipeline finished with Failed
    7 months ago
    Total: 246s
    #286851
  • Pipeline finished with Skipped
    7 months ago
    #294096
  • Pipeline finished with Failed
    7 months ago
    Total: 207s
    #294206
  • Pipeline finished with Failed
    7 months ago
    Total: 480s
    #294624
  • Pipeline finished with Failed
    7 months ago
    Total: 177s
    #294658
  • Pipeline finished with Success
    7 months ago
    Total: 167s
    #294721
  • Pipeline finished with Success
    7 months ago
    Total: 3135s
    #296773
  • Pipeline finished with Failed
    6 months ago
    Total: 163s
    #299054
  • Pipeline finished with Failed
    6 months ago
    Total: 214s
    #299063
  • Pipeline finished with Success
    6 months ago
    Total: 171s
    #299074
  • Pipeline finished with Success
    6 months ago
    Total: 174s
    #299079
  • Pipeline finished with Success
    6 months ago
    Total: 285s
    #303666
  • Pipeline finished with Canceled
    6 months ago
    #303677
  • Pipeline finished with Success
    6 months ago
    Total: 231s
    #303687
  • Pipeline finished with Success
    6 months ago
    Total: 292s
    #320030
  • Pipeline finished with Failed
    6 months ago
    Total: 172s
    #321143
  • Pipeline finished with Failed
    6 months ago
    Total: 340s
    #321150
  • Pipeline finished with Failed
    6 months ago
    Total: 500s
    #321153
  • Pipeline finished with Success
    6 months ago
    Total: 134s
    #324020
  • Pipeline finished with Success
    5 months ago
    #337690
  • Pipeline finished with Success
    5 months ago
    Total: 115s
    #348687
  • Pipeline finished with Failed
    5 months ago
    Total: 2278s
    #350115
  • Pipeline finished with Canceled
    5 months ago
    Total: 97s
    #350158
  • Pipeline finished with Success
    5 months ago
    Total: 161s
    #350263
  • Pipeline finished with Success
    5 months ago
    Total: 148s
    #351011
  • Pipeline finished with Success
    4 months ago
    Total: 149s
    #360342
  • Pipeline finished with Success
    4 months ago
    Total: 246s
    #367598
  • Pipeline finished with Success
    4 months ago
    Total: 370s
    #367638
  • Pipeline finished with Canceled
    4 months ago
    Total: 80s
    #367704
  • Pipeline finished with Success
    4 months ago
    Total: 143s
    #367712
  • Pipeline finished with Success
    4 months ago
    #368430
  • Pipeline finished with Success
    4 months ago
    Total: 181s
    #368863
  • Pipeline finished with Success
    4 months ago
    Total: 203s
    #374204
  • Pipeline finished with Success
    4 months ago
    Total: 164s
    #379034
  • Pipeline finished with Success
    4 months ago
    #380618
  • Pipeline finished with Canceled
    4 months ago
    Total: 87s
    #380638
  • Pipeline finished with Success
    4 months ago
    Total: 167s
    #380639
  • Pipeline finished with Canceled
    4 months ago
    Total: 123s
    #380648
  • Pipeline finished with Failed
    3 months ago
    Total: 357s
    #398418
  • Pipeline finished with Success
    3 months ago
    Total: 263s
    #401626
  • Pipeline finished with Success
    3 months ago
    Total: 199s
    #401634
  • Pipeline finished with Failed
    2 months ago
    Total: 191s
    #422219
  • Pipeline finished with Failed
    2 months ago
    Total: 240s
    #422246
  • Pipeline finished with Failed
    about 2 months ago
    Total: 140s
    #429050
  • Pipeline finished with Success
    about 2 months ago
    Total: 225s
    #432128
  • Pipeline finished with Success
    about 1 month ago
    Total: 272s
    #438009
  • Pipeline finished with Success
    about 1 month ago
    Total: 194s
    #440769
  • Pipeline finished with Success
    about 1 month ago
    Total: 276s
    #444724
  • Pipeline finished with Success
    about 1 month ago
    Total: 290s
    #445359
  • Pipeline finished with Success
    about 1 month ago
    Total: 292s
    #447438
  • Pipeline finished with Canceled
    26 days ago
    Total: 281s
    #452504
  • Pipeline finished with Success
    26 days ago
    Total: 383s
    #452508
  • Pipeline finished with Success
    16 days ago
    Total: 387s
    #460760
  • Pipeline finished with Success
    5 days ago
    Total: 184s
    #470276
  • Pipeline finished with Success
    5 days ago
    Total: 214s
    #470286
  • Pipeline finished with Success
    4 days ago
    Total: 190s
    #470298
Production build 0.71.5 2024