Uncaught PHP exception with 5.0.15 on Drupal < 10.3.x

Created on 19 July 2024, 9 months ago
Updated 6 August 2024, 8 months ago

Problem/Motivation

After upgrading charts to 5.0.15 on a site on Drupal 10.2.7 we get "Uncaught PHP Exception Error: "Class "Drupal\Core\Render\Element\RenderElementBase" not found" at /var/www/html/web/modules/contrib/charts/src/Element/ChartAxisBase.php line 10"

Steps to reproduce

Create a new project on 10.2.7, require drupal/charts and enable the module. Visit the site.
Something like this:

#!/bin/bash
composer create-project drupal/recommended-project:10.2.7 test-project
cd test-project
composer require drush/drush drupal/charts
vendor/bin/drush si standard --db-url=mysql://db:db@db/db --account-name=admin --account-pass=1 -y
vendor/bin/drush en charts

Proposed resolution

Require drupal core ^10.3

Remaining tasks

User interface changes

API changes

Data model changes

πŸ› Bug report
Status

Fixed

Version

5.0

Component

Code

Created by

πŸ‡³πŸ‡΄Norway jfauske

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

Merge Requests

Comments & Activities

  • Issue created by @jfauske
  • πŸ‡ΊπŸ‡ΈUnited States andileco

    Thanks for reporting. You can pin to 5.0.14 in the meantime while a fix this.

  • πŸ‡ΊπŸ‡ΈUnited States SocialNicheGuru

    Drupal 10.3 is introducing

  • πŸ‡ΊπŸ‡ΈUnited States contiveros@azwater.gov

    This issue is also affecting Drupal 9.5.11 and completely hosing the site.

    The website encountered an unexpected error. Please try again later.
    Error: Class "Drupal\Core\Render\Element\FormElementBase" not found in include() (line 39 of modules/contrib/charts/src/Element/BaseSettings.php).
    include() (Line: 576)
    Composer\Autoload\{closure}('/code/web/modules/contrib/charts/src/Element/BaseSettings.php') (Line: 427)
    Composer\Autoload\ClassLoader->loadClass('Drupal\charts\Element\BaseSettings')
    class_exists('Drupal\charts\Element\BaseSettings') (Line: 96)
    Drupal\Component\Plugin\Factory\DefaultFactory::getPluginClass('charts_settings', Array, 'Drupal\Core\Render\Element\ElementInterface') (Line: 17)
    Drupal\Core\Plugin\Factory\ContainerFactory->createInstance('charts_settings', Array) (Line: 83)
    Drupal\Component\Plugin\PluginManagerBase->createInstance('charts_settings', Array) (Line: 141)
    Drupal\Core\Render\ElementInfoManager->createInstance('charts_settings') (Line: 111)
    Drupal\Core\Render\ElementInfoManager->buildInfo('claro') (Line: 77)
    Drupal\Core\Render\ElementInfoManager->getInfo('html') (Line: 312)
    Drupal\Core\Render\Renderer->doRender(Array, 1) (Line: 204)
    Drupal\Core\Render\Renderer->render(Array, 1) (Line: 148)
    Drupal\Core\Render\Renderer->Drupal\Core\Render\{closure}() (Line: 580)
    Drupal\Core\Render\Renderer->executeInRenderContext(Object, Object) (Line: 149)
    Drupal\Core\Render\Renderer->renderRoot(Array) (Line: 66)
    Drupal\Core\Render\BareHtmlPageRenderer->renderBarePage(Array, Object, 'maintenance_page', Array) (Line: 76)
    Drupal\Core\ProxyClass\Render\BareHtmlPageRenderer->renderBarePage(Array, Object, 'maintenance_page', Array) (Line: 196)
    Drupal\system\Controller\DbUpdateController->handle('info', Object)
    call_user_func_array(Array, Array) (Line: 115)
    Drupal\Core\Update\UpdateKernel->handleRaw(Object) (Line: 76)
    Drupal\Core\Update\UpdateKernel->handle(Object) (Line: 27)
  • πŸ‡ΊπŸ‡ΈUnited States andileco

    @contiveros@azwater.gov, yes - this is for 10.3 and greater. It was not clear to me how new these base classes were. Please use 5.0.14.

  • Merge request !103Update 14 files β†’ (Merged) created by andileco
  • Pipeline finished with Skipped
    9 months ago
    #231492
    • andileco β†’ committed 93a29942 on 5.0.x
      Issue #3462637: Uncaught PHP exception with 5.0.15 on Drupal < 10.3.x
      
  • Status changed to Fixed 9 months ago
  • πŸ‡ΊπŸ‡ΈUnited States andileco

    So issued two releases:

    • 10.2 and below should use 5.0.16
    • 10.3 and above should use 5.1.0
  • πŸ‡³πŸ‡΄Norway jfauske

    Thanks a lot @andileco!

    Can confim issue gone with 5.0.16 and 5.1.0 on 10.2.x and 10.3.x respectively.

  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024