- Issue created by @orkut murat yılmaz
- 🇩🇪Germany alxn
I received similar warnings with drupal/core 10.3.10 and doctrine/deprecations 1.1.4 when visiting pages under /admin:
Warning: include(): Failed opening '/var/www/html/vendor/composer/../doctrine/deprecations/lib/Doctrine/Deprecations/Deprecation.php' for inclusion (include_path='/var/www/html/vendor/pear/archive_tar:/var/www/html/vendor/pear/console_getopt:/var/www/html/vendor/pear/pear-core-minimal/src:/var/www/html/vendor/pear/pear_exception:.:/usr/local/lib/php') in include() (Line 576 in /var/www/html/vendor/composer/ClassLoader.php) #0 /var/www/html/docroot/core/includes/bootstrap.inc(166): _drupal_error_handler_real() #1 /var/www/html/vendor/composer/ClassLoader.php(576): _drupal_error_handler() #2 /var/www/html/vendor/composer/ClassLoader.php(576): include('...') #3 /var/www/html/vendor/composer/ClassLoader.php(427): Composer\Autoload\{closure}() #4 /var/www/html/vendor/doctrine/lexer/src/Token.php(104): Composer\Autoload\ClassLoader->loadClass() #5 /var/www/html/docroot/core/lib/Drupal/Component/Annotation/Doctrine/DocParser.php(619): Doctrine\Common\Lexer\Token->offsetGet() ...
Warnings went away after downgrading to doctrine/deprecations 1.1.3.
- 🇹🇷Turkey orkut murat yılmaz Istanbul
When check the browser, I see the WSOD, with the full error message below:
The website encountered an unexpected error. Try again later. Error: Class "Doctrine\Deprecations\Deprecation" not found in Doctrine\Common\Lexer\Token->offsetGet() (line 104 of /var/www/html/vendor/doctrine/lexer/src/Token.php). Doctrine\Common\Lexer\Token->offsetGet() (Line: 619) Drupal\Component\Annotation\Doctrine\DocParser->Annotations() (Line: 338) Drupal\Component\Annotation\Doctrine\DocParser->parse() (Line: 101) Drupal\Component\Annotation\Doctrine\SimpleAnnotationReader->getClassAnnotations() (Line: 125) Drupal\Component\Annotation\Doctrine\SimpleAnnotationReader->getClassAnnotation() (Line: 145) Drupal\Component\Annotation\Plugin\Discovery\AnnotatedClassDiscovery->getDefinitions() (Line: 119) Drupal\Core\Entity\EntityTypeManager->findDefinitions() (Line: 213) Drupal\Core\Plugin\DefaultPluginManager->getDefinitions() (Line: 22) Drupal\Core\Plugin\DefaultPluginManager->getDefinition() (Line: 135) Drupal\Core\Entity\EntityTypeManager->getDefinition() (Line: 260) Drupal\Core\Entity\EntityTypeManager->getHandler() (Line: 195) Drupal\Core\Entity\EntityTypeManager->getStorage() (Line: 42) Drupal\eca\Token\CurrentUserDataProvider->__construct() (Line: 261) Drupal\Component\DependencyInjection\Container->createService() (Line: 179) Drupal\Component\DependencyInjection\Container->get() (Line: 438) Drupal\Component\DependencyInjection\Container->resolveServicesAndParameters() (Line: 275) Drupal\Component\DependencyInjection\Container->createService() (Line: 179) Drupal\Component\DependencyInjection\Container->get() (Line: 438) Drupal\Component\DependencyInjection\Container->resolveServicesAndParameters() (Line: 239) Drupal\Component\DependencyInjection\Container->createService() (Line: 179) Drupal\Component\DependencyInjection\Container->get() (Line: 438) Drupal\Component\DependencyInjection\Container->resolveServicesAndParameters() (Line: 239) Drupal\Component\DependencyInjection\Container->createService() (Line: 179) Drupal\Component\DependencyInjection\Container->get() (Line: 105) Drupal\Component\EventDispatcher\ContainerAwareEventDispatcher->dispatch() (Line: 239) Symfony\Component\HttpKernel\HttpKernel->handleThrowable() (Line: 91) Symfony\Component\HttpKernel\HttpKernel->handle() (Line: 53) Drupal\Core\StackMiddleware\Session->handle() (Line: 48) Drupal\Core\StackMiddleware\KernelPreHandle->handle() (Line: 28) Drupal\Core\StackMiddleware\ContentLength->handle() (Line: 32) Drupal\big_pipe\StackMiddleware\ContentLength->handle() (Line: 116) Drupal\page_cache\StackMiddleware\PageCache->pass() (Line: 90) Drupal\page_cache\StackMiddleware\PageCache->handle() (Line: 50) Drupal\ban\BanMiddleware->handle() (Line: 48) Drupal\Core\StackMiddleware\ReverseProxyMiddleware->handle() (Line: 51) Drupal\Core\StackMiddleware\NegotiationMiddleware->handle() (Line: 36) Drupal\Core\StackMiddleware\AjaxPageState->handle() (Line: 51) Drupal\Core\StackMiddleware\StackedHttpKernel->handle() (Line: 741) Drupal\Core\DrupalKernel->handle() (Line: 19)
- 🇹🇷Turkey orkut murat yılmaz Istanbul
When I updated my core with drupal 10.4.x-dev, I start reaching to my web interface and all the errors become warnings. After rebuilding the cache, warnings disappear, as told on comment #2.
- 🇬🇧United Kingdom joachim
I got this on Drupal 10.3.x, when I upgraded drupal/csv_serialization from 4.0.0 => 4.0.1.
The problem appears to be doctrine/deprecations 1.1.4. I forced a downgrade of that to the previous version I had -- 1.1.3 -- and with no other package changes, the error stopped.
Should this not be major or critical?
- 🇫🇷France guilhom Toulouse
I can confirm that I also updated some modules few minutes ago and received the same error with WSOD on multiple pages.
It appears indeed that doctrine/deprecations 1.1.4 is the problem.
Downgrading to 1.1.3 error disappears. - 🇬🇧United Kingdom joachim
The problem is that the class has been moved:
> lib/Doctrine/Deprecations/Deprecation.php → src/Deprecation.php
I don't know why autoload hasn't caught up.
- 🇫🇷France guilhom Toulouse
Running
composer dump-autoload -o
seems to help.
From what I see on doctrine/deprecations, they moved source location from lib/ to src/ - 🇩🇪Germany alxn
I could now reproduce the WSOD error with Drupal 10.3.10 and doctrine/deprecations 1.1.4, it was shown after clearing the cache and editing a field of a content type. The error went away with doctrine/deprecations 1.1.3.
- 🇫🇷France dcoppel
After upgrade doctrine/deprecations from 1.1.3 to 1.1.4 my drupal site crash with this error : Uncaught PHP Exception Drupal\\Component\\Plugin\\Exception\\PluginNotFoundException: "The "broken" plugin does not exist. Valid plugin IDs for Drupal\\views\\Plugin\\ViewsHandlerManager are: datetime, groupby_numeric, date, random" at myrootsite/web/core/lib/Drupal/Component/Plugin/Discovery/DiscoveryTrait.php line 53
- 🇫🇷France andypost
I bet it duplicates 📌 Update Composer dependencies for 10.4.0-RC1 Active
- 🇻🇳Vietnam datati
I have the same problem when upgrading doctrine/deprecations:1.1.3 to 1.1.4. I have to downgrade it. The site is back. Waiting for the problem to be fixed.
composer require doctrine/deprecations:1.1.3
- 🇺🇸United States sissi.schulmeister
After upgrading the Diff module from 8.x-1.7 to 8.x-1.8 on a Drupal 10.3.x site, I am getting a WSOD and the same error as mentioned: Error: Class "Doctrine\Deprecations\Deprecation" not found in Doctrine\Common\Lexer\Token->offsetGet() (line 104 of /var/www/vendor/doctrine/lexer/src/Token.php).
- 🇺🇸United States josh.fabean
I also am getting this trying to upgrade to 10.3.10, for me downgrading doctrine/deprecations:1.1.3 isn't working.
I'm also getting this issue,
For me was after updating the taxonomy manager module.
As the original post, stated also deleted the "vendor" directory and re-run the composer install command, but it didn't work.My only way to get out of this issue was to reimport the database from previous backup.
- 🇧🇪Belgium shaesen Mechelen
Same issue here on multiple sites today after running 'composer update' for Gin Theme and Gin Toolbar.
Downgrade of doctrine/depreciations to 1.1.3 solves the issue
- 🇬🇧United Kingdom longwave UK
As per this GitHub comment it's likely that if you are suffering from this after updating then you need to also clear your APCu cache - the easiest way to do this is to restart your webserver or PHP-FPM.
- 🇳🇿New Zealand quietone
Restore the standard issue template and updated the proposed resolution to direct to #19.
- 🇬🇧United Kingdom fonant
Re-starting
php-fpm
fixed the problem for me - thanks for the tip @longwave! - 🇬🇧United Kingdom longwave UK
Thanks for confirming, marking this fixed as I believe that is the solutionm for all affected sites - there is nothing we can do in Drupal core to help with this.
- 🇺🇸United States aryosys
Re-starting php-fpm fixed the problem for me - thanks for the tip @longwave!
- 🇫🇷France eddylbs Paris
Hello,
Downgrade of doctrine/depreciations to 1.1.3 in #14 works for me.
Thanks.
I don't agree that this isn't a breaking change, because it is in fact in some cases. For Drupal sites on shared hosting, a bugfix release like 1.1.4 may require opening a support ticket with the hosting company to have a restart. And yes, I understand that mitigations on the library maintainer's side are not easy. They are not even practical in many cases.
Drupal's PHP requirements → say nothing about needing to restart the PHP process during deployments. I asked at #3153335: Document $settings['deployment_identifier'] (and that it fixes moved class autoloader caching) → if that documentation would be sufficient in a case like this. If it isn't we need to update the PHP requirements accordingly.
I've got this after installing the feeds module:
composer require 'drupal/feeds:^3.0@RC'
.Running
composer dump-autoload
-o as suggested by @guilhom worked for me! Thanks @guilhom!- 🇬🇧United Kingdom joachim
Should we update our requirements to say that the PHP file cache should be clearer whenever modules or Composer packages are updated?
This could happen again any time that a package decides to move a class.
It could also happen if a package uses 3rd-party attributes -- see ✨ Allow attribute-based plugins to discover supplemental attributes from other modules Active .
Probably. And then there is the auto-updates feature to consider.
- 🇪🇨Ecuador andres.torres
Just ran a composer update --with-dependencies on a Drupal 10.3.10 site and found the issue described here but as stated on comment #19 just needed to restart the apache and php-fpm services and site went back to normal, no need to downgrade Doctrine.
- 🇦🇹Austria nofue
Merci guilhom, #9 is the solution:
composer dump-autoload -o
- 🇨🇭Switzerland handkerchief
In my case it was the installation of the Webform libraries: https://www.drupal.org/node/3003140 →
... which caused the error#19
composer dump-autoload -o
was also the solution. Hope there is no downside to this. - 🇺🇸United States greatmatter
Thank you @guilhom - composer dump-autoload -o did the trick.
- 🇮🇳India ashwinsh Pune
https://www.drupal.org/project/drupal/issues/3492523#comment-15892853 🐛 Class "Doctrine\Deprecations\Deprecation" not found Active is working for me
- 🇺🇸United States vardhan400 Boston
Hello,
Downgrade of doctrine/depreciations to 1.1.3 in #14 resulted in the following warnings
Warning: include(): Failed opening '/var/www/vendor/composer/../doctrine/deprecations/lib/Doctrine/Deprecations/Deprecation.php' for inclusion (include_path='/var/www/vendor/pear/archive_tar:/var/www/vendor/pear/console_getopt:/var/www/vendor/pear/pear-core-minimal/src:/var/www/vendor/pear/pear_exception:.:/usr/local/lib/php') in include() (line 576 of /var/www/vendor/composer/ClassLoader.php).
After restarting the local server, the warnings were resolved on my end.
- 🇩🇪Germany quotientix
I'm working on a server that I can't access via console/composer directly and I can't restart it manually. Any ideas on how to fix this?
- 🇺🇸United States jastraat
It sounds like the deployment_identifier setting might be a good approach: https://www.drupal.org/project/drupal/issues/3153335 →
- 🇬🇧United Kingdom joachim
AFAICT (with no docs it's hard to be sure, hence that issue!!!) deployment_identifier only causes a container rebuild. The PHP file cache is something below that, isn't it?
- 🇬🇧United Kingdom longwave UK
Yeah, I don't think
deployment_identifier
will have any effect on this. I think only the list of enabled modules is considered. FromDrupalKernel::boot()
:// Add the APCu prefix to use to cache found/not-found classes. if (Settings::get('class_loader_auto_detect', TRUE) && method_exists($this->classLoader, 'setApcuPrefix')) { // Vary the APCu key by which modules are installed to allow // class_exists() checks to determine functionality. $id = 'class_loader:' . crc32(implode(':', array_keys($this->container->getParameter('container.modules')))); $prefix = Settings::getApcuPrefix($id, $this->root); $this->classLoader->setApcuPrefix($prefix); }
We could add
deployment_identifier
to that cache key? - 🇬🇧United Kingdom joachim
That still relies on the site owner knowing that this needs doing, and understanding how to handle a crash like the one in the IS. It's still going to leave a lot of people confused.
Shouldn't Composer clear the apcu cache whenever the composer.lock hash changes?
- 🇨🇦Canada softstart
Thank you @guilhom #9 - composer dump-autoload -o worked for me.
- 🇺🇦Ukraine mamoruua
Thank you @guilhom #9
composer dump-autoload -o
worked for me too. Automatically closed - issue fixed for 2 weeks with no activity.