diff --git a/core/lib/Drupal/Core/Extension/ExtensionList.php b/core/lib/Drupal/Core/Extension/ExtensionList.php index f12c9a61f830f136645de3bc36f002325566bec8..38f0f9f824664c8fb2cd9bbe0f9f7846e1f47d30 100644 --- a/core/lib/Drupal/Core/Extension/ExtensionList.php +++ b/core/lib/Drupal/Core/Extension/ExtensionList.php @@ -559,8 +559,13 @@ protected function createExtensionInfo(Extension $extension) { // contributed extensions to use for ordering extension lists. $info['mtime'] = $extension->getFileInfo()->getMTime(); - // Merge extension type-specific defaults. - $info += $this->defaults; + // Merge extension type-specific defaults, making sure to replace NULL + // values. + foreach ($this->defaults as $key => $default_value) { + if (!isset($info[$key])) { + $info[$key] = $default_value; + } + } return $info; } diff --git a/core/modules/system/tests/src/Functional/Form/ModulesListFormWebTest.php b/core/modules/system/tests/src/Functional/Form/ModulesListFormWebTest.php index ab8b18e4d0ee3bbc4bceb61e0260a7aaab320a95..ac78f4b7a8ff49e0e371e9cce8297519a37ca7d4 100644 --- a/core/modules/system/tests/src/Functional/Form/ModulesListFormWebTest.php +++ b/core/modules/system/tests/src/Functional/Form/ModulesListFormWebTest.php @@ -121,6 +121,34 @@ public function testModulesListFormWithInvalidInfoFile() { $this->assertSession()->pageTextNotContains('Modules could not be listed due to an error'); } + /** + * Tests the module form with a module with an empty description in info.yml. + */ + public function testModulesListFormWithEmptyDescriptionInfoFile() { + $path = \Drupal::getContainer() + ->getParameter('site.path') . "/modules/missing_description"; + mkdir($path, 0777, TRUE); + $file_path = "$path/missing_description.info.yml"; + + $yml = <<<BROKEN +name: Module with empty description +type: module +core_version_requirement: '*' +description: +BROKEN; + + file_put_contents($file_path, $yml); + + $this->drupalGet('admin/modules'); + $this->assertSession()->statusCodeEquals(200); + + $this->assertSession() + ->pageTextContains("Module with empty description"); + + // Check that the module filter text box is available. + $this->assertSession()->elementExists('xpath', '//input[@name="text"]'); + } + /** * Confirm that module 'Required By' descriptions include dependent themes. */