Error during drush updb datetime_range_post_update_from_to_configuration

Created on 7 August 2024, 8 months ago
Updated 20 August 2024, 8 months ago

Problem/Motivation

Upgrading my website

  • drupal/core : 10.2.7 => 10.3.1
  • drupal/media_avportal : 1.6.0 => 1.8.0

I had this error :

[Exec] Running ./vendor/bin/drush updatedb -y
 ----------- --------------- --------------- ---------------------------------- 
  Module      Update ID       Type            Description                       
 ----------- --------------- --------------- ---------------------------------- 
  datetime_   from_to_confi   post-update     Adds 'from_to' in flagged entity  
  range       guration                        view date range formatter.        
                                              @see                              
                                              \datetime_range_entity_view_disp  
                                              lay_presave                                 
 ----------- --------------- --------------- ---------------------------------- 


 // Do you wish to run the specified pending updates?: yes.                                                            

>  [notice] Update started: datetime_range_post_update_from_to_configuration
> TypeError: Drupal\media_avportal\Plugin\media\Source\MediaAvPortalSourceBase::__construct(): Argument #8 ($logger) must be of type Drupal\Core\Logger\LoggerChannelInterface, Psr\Log\NullLogger given, called in web/modules/contrib/media_avportal/src/Plugin/media/Source/MediaAvPortalSourceBase.php on line 118 in web/modules/contrib/media_avportal/src/Plugin/media/Source/MediaAvPortalSourceBase.php on line 91 #0 web/modules/contrib/media_avportal/src/Plugin/media/Source/MediaAvPortalSourceBase.php(118): Drupal\media_avportal\Plugin\media\Source\MediaAvPortalSourceBase->__construct()
> #1 web/core/lib/Drupal/Core/Plugin/Factory/ContainerFactory.php(21): Drupal\media_avportal\Plugin\media\Source\MediaAvPortalSourceBase::create()
> #2 web/core/lib/Drupal/Component/Plugin/PluginManagerBase.php(83): Drupal\Core\Plugin\Factory\ContainerFactory->createInstance()
> #3 web/core/lib/Drupal/Core/Plugin/DefaultSingleLazyPluginCollection.php(62): Drupal\Component\Plugin\PluginManagerBase->createInstance()
> #4 web/core/lib/Drupal/Component/Plugin/LazyPluginCollection.php(80): Drupal\Core\Plugin\DefaultSingleLazyPluginCollection->initializePlugin()
> #5 web/core/lib/Drupal/Core/Plugin/DefaultSingleLazyPluginCollection.php(88): Drupal\Component\Plugin\LazyPluginCollection->get()
> #6 web/core/lib/Drupal/Core/Plugin/DefaultSingleLazyPluginCollection.php(104): Drupal\Core\Plugin\DefaultSingleLazyPluginCollection->setConfiguration()
> #7 web/core/lib/Drupal/Core/Plugin/DefaultSingleLazyPluginCollection.php(55): Drupal\Core\Plugin\DefaultSingleLazyPluginCollection->addInstanceId()
> #8 web/core/modules/media/src/Entity/MediaType.php(204): Drupal\Core\Plugin\DefaultSingleLazyPluginCollection->__construct()
> #9 web/core/modules/media/src/Entity/MediaType.php(193): Drupal\media\Entity\MediaType->sourcePluginCollection()
> #10 web/modules/contrib/media_entity_file_replace/media_entity_file_replace.module(46): Drupal\media\Entity\MediaType->getSource()
> #11 [internal function]: media_entity_file_replace_entity_extra_field_info()
> #12 web/core/lib/Drupal/Core/Extension/ModuleHandler.php(416): call_user_func_array()
> #13 web/core/lib/Drupal/Core/Extension/ModuleHandler.php(395): Drupal\Core\Extension\ModuleHandler->Drupal\Core\Extension\{closure}()
> #14 web/core/lib/Drupal/Core/Extension/ModuleHandler.php(423): Drupal\Core\Extension\ModuleHandler->invokeAllWith()
> #15 web/core/lib/Drupal/Core/Entity/EntityFieldManager.php(676): Drupal\Core\Extension\ModuleHandler->invokeAll()
> #16 web/core/lib/Drupal/Core/Entity/EntityFieldManager.php(649): Drupal\Core\Entity\EntityFieldManager->loadExtraFields()
> #17 web/core/lib/Drupal/Core/Entity/EntityDisplayBase.php(173): Drupal\Core\Entity\EntityFieldManager->getExtraFields()
> #18 web/core/lib/Drupal/Core/Entity/EntityDisplayBase.php(155): Drupal\Core\Entity\EntityDisplayBase->init()
> #19 web/core/lib/Drupal/Core/Entity/Entity/EntityViewDisplay.php(181): Drupal\Core\Entity\EntityDisplayBase->__construct()
> #20 web/core/lib/Drupal/Core/Entity/EntityStorageBase.php(418): Drupal\Core\Entity\Entity\EntityViewDisplay->__construct()
> #21 web/core/lib/Drupal/Core/Config/Entity/ConfigEntityStorage.php(186): Drupal\Core\Entity\EntityStorageBase->mapFromStorageRecords()
> #22 web/core/lib/Drupal/Core/Entity/EntityStorageBase.php(312): Drupal\Core\Config\Entity\ConfigEntityStorage->doLoadMultiple()
> #23 web/core/lib/Drupal/Core/Config/Entity/ConfigEntityUpdater.php(136): Drupal\Core\Entity\EntityStorageBase->loadMultiple()
> #24 web/core/modules/datetime_range/datetime_range.post_update.php(58): Drupal\Core\Config\Entity\ConfigEntityUpdater->update()
> #25 vendor/drush/drush/src/Commands/core/UpdateDBCommands.php(280): datetime_range_post_update_from_to_configuration()
> #26 vendor/drush/drush/includes/batch.inc(257): Drush\Commands\core\UpdateDBCommands::updateDoOnePostUpdate()
> #27 vendor/drush/drush/includes/batch.inc(204): _drush_batch_worker()
> #28 vendor/drush/drush/includes/batch.inc(75): _drush_batch_command()
> #29 vendor/drush/drush/src/Commands/core/UpdateDBCommands.php(136): drush_batch_command()
> #30 [internal function]: Drush\Commands\core\UpdateDBCommands->process()
> #31 vendor/consolidation/annotated-command/src/CommandProcessor.php(276): call_user_func_array()
> #32 vendor/consolidation/annotated-command/src/CommandProcessor.php(212): Consolidation\AnnotatedCommand\CommandProcessor->runCommandCallback()
> #33 vendor/consolidation/annotated-command/src/CommandProcessor.php(176): Consolidation\AnnotatedCommand\CommandProcessor->validateRunAndAlter()
> #34 vendor/consolidation/annotated-command/src/AnnotatedCommand.php(391): Consolidation\AnnotatedCommand\CommandProcessor->process()
> #35 vendor/symfony/console/Command/Command.php(326): Consolidation\AnnotatedCommand\ nnotatedCommand->execute()
> #36 vendor/symfony/console/Application.php(1096): Symfony\Component\Console\Command\Command->run()
> #37 vendor/symfony/console/Application.php(324): Symfony\Component\Console\Application->doRunCommand()
> #38 vendor/symfony/console/Application.php(175): Symfony\Component\Console\Application->doRun()
> #39 vendor/drush/drush/src/Runtime/Runtime.php(110): Symfony\Component\Console\Application->run()
> #40 vendor/drush/drush/src/Runtime/Runtime.php(40): Drush\Runtime\Runtime->doRun()
> #41 vendor/drush/drush/drush.php(139): Drush\Runtime\Runtime->run()
> #42 vendor/drush/drush/drush(4): require('...')
> #43 vendor/bin/drush(119): include('...')
> #44 {main}
>  [warning] Drush command terminated abnormally.

Unable to decode output into JSON: Syntax error                                                                     
                                                                                                                      
  TypeError: Drupal\media_avportal\Plugin\media\Source\MediaAvPortalSourceBase::__construct(): Argument #8 ($logger)  
   must be of type Drupal\Core\Logger\LoggerChannelInterface, Psr\Log\NullLogger given, called in web/modules/contrib/media_avportal/src/Plugin/media/Source/MediaAvPortalSourceBase.php on line 118   
  in Drupal\media_avportal\Plugin\media\Source\MediaAvPortalSourceBase->__construct() (line 91 of web/modules/contrib/media_avportal/src/Plugin/media/Source/MediaAvPortalSourceBase.php).

Technical explanation

Psr\Log\LoggerInterface
├── AbstractLogger
│   └── NullLogger
└── Drupal\Core\Logger\LoggerChannelInterface

$logger was Drupal\Core\Logger\LoggerChannelInterface but we were receiving Psr\Log\NullLogger.

Technical solution

$logger have to be of type LoggerInterface to be less restrictive

🐛 Bug report
Status

Closed: works as designed

Version

1.8

Component

Code

Created by

🇫🇷France Julien Tekrane

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

Merge Requests

Comments & Activities

Production build 0.71.5 2024