From d0e9ea098096c6ea3be2e1fbee857fcc38186e1a Mon Sep 17 00:00:00 2001 From: Lee Rowlands Date: Tue, 7 Jul 2020 12:05:13 +1000 Subject: [PATCH] Issue #2914785 by acbramley, jungle, Hardik_Patel_12, mrinalini9, larowlan: Entities with external urls as a uri relationship can not be deleted when menu_link_content is installed --- .../menu_link_content.module | 5 +++ .../tests/src/Kernel/MenuLinksTest.php | 15 +++++--- .../src/Entity/EntityTestExternal.php | 36 +++++++++++++++++++ 3 files changed, 52 insertions(+), 4 deletions(-) create mode 100644 core/modules/system/tests/modules/entity_test/src/Entity/EntityTestExternal.php diff --git a/core/modules/menu_link_content/menu_link_content.module b/core/modules/menu_link_content/menu_link_content.module index def0ed9db0..a593bef4e3 100644 --- a/core/modules/menu_link_content/menu_link_content.module +++ b/core/modules/menu_link_content/menu_link_content.module @@ -104,6 +104,11 @@ function menu_link_content_entity_predelete(EntityInterface $entity) { $entity_type_id = $entity->getEntityTypeId(); foreach ($entity->uriRelationships() as $rel) { $url = $entity->toUrl($rel); + // Entities can provide uri relationships that are not routed, in this case + // getRouteParameters() will throw an exception. + if (!$url->isRouted()) { + continue; + } $route_parameters = $url->getRouteParameters(); if (!isset($route_parameters[$entity_type_id])) { // Do not delete links which do not relate to this exact entity. For diff --git a/core/modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php b/core/modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php index d7d3812f70..6883c76abb 100644 --- a/core/modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php +++ b/core/modules/menu_link_content/tests/src/Kernel/MenuLinksTest.php @@ -4,6 +4,7 @@ use Drupal\Component\Render\FormattableMarkup; use Drupal\Core\Menu\MenuTreeParameters; +use Drupal\entity_test\Entity\EntityTestExternal; use Drupal\KernelTests\KernelTestBase; use Drupal\menu_link_content\Entity\MenuLinkContent; use Drupal\system\Entity\Menu; @@ -17,11 +18,10 @@ class MenuLinksTest extends KernelTestBase { /** - * Modules to enable. - * - * @var array + * {@inheritdoc} */ - public static $modules = [ + protected static $modules = [ + 'entity_test', 'link', 'menu_link_content', 'router_test', @@ -46,6 +46,7 @@ protected function setUp() { $this->installSchema('system', ['sequences']); $this->installSchema('user', ['users_data']); + $this->installEntitySchema('entity_test_external'); $this->installEntitySchema('menu_link_content'); $this->installEntitySchema('user'); @@ -163,6 +164,12 @@ public function testMenuLinkOnEntityDelete() { $user = User::create(['name' => 'username']); $user->save(); + // Create External test entity. + $external_entity = EntityTestExternal::create(); + $external_entity->save(); + // Ensure an external entity can be deleted. + $external_entity->delete(); + // Create "canonical" menu link pointing to the user. $menu_link_content = MenuLinkContent::create([ 'title' => 'username profile', diff --git a/core/modules/system/tests/modules/entity_test/src/Entity/EntityTestExternal.php b/core/modules/system/tests/modules/entity_test/src/Entity/EntityTestExternal.php new file mode 100644 index 0000000000..b6587a9a9e --- /dev/null +++ b/core/modules/system/tests/modules/entity_test/src/Entity/EntityTestExternal.php @@ -0,0 +1,36 @@ +