trait MenuUiTrait in Drupal 9
Same name and namespace in other branches
- 8 core/modules/menu_ui/tests/src/Traits/MenuUiTrait.php \Drupal\Tests\menu_ui\Traits\MenuUiTrait
Provides common methods for Menu UI module tests.
Hierarchy
- trait \Drupal\Tests\menu_ui\Traits\MenuUiTrait
3 files declare their use of MenuUiTrait
- MenuUiJavascriptTest.php in core/
modules/ menu_ui/ tests/ src/ FunctionalJavascript/ MenuUiJavascriptTest.php - MenuUiLanguageTest.php in core/
modules/ menu_ui/ tests/ src/ Functional/ MenuUiLanguageTest.php - MenuUiTest.php in core/
modules/ menu_ui/ tests/ src/ Functional/ MenuUiTest.php
File
- core/
modules/ menu_ui/ tests/ src/ Traits/ MenuUiTrait.php, line 8
Namespace
Drupal\Tests\menu_ui\TraitsView source
trait MenuUiTrait {
/**
* Asserts that a menu fetched from the database matches an expected one.
*
* @param array $expected_item
* Array containing properties to check.
* @param int $menu_plugin_id
* Menu item id.
*/
protected function assertMenuLink(array $expected_item, $menu_plugin_id) {
// Retrieve the menu link.
/** @var \Drupal\Core\Menu\MenuLinkManagerInterface $menu_link_manager */
$menu_link_manager = \Drupal::service('plugin.manager.menu.link');
$menu_link_manager
->resetDefinitions();
// Reset the static load cache.
\Drupal::entityTypeManager()
->getStorage('menu_link_content')
->resetCache();
$definition = $menu_link_manager
->getDefinition($menu_plugin_id);
$entity = NULL;
// Pull the path from the menu link content.
if (strpos($menu_plugin_id, 'menu_link_content') === 0) {
list(, $uuid) = explode(':', $menu_plugin_id, 2);
/** @var \Drupal\menu_link_content\Entity\MenuLinkContent $entity */
$entity = \Drupal::service('entity.repository')
->loadEntityByUuid('menu_link_content', $uuid);
}
if (isset($expected_item['children'])) {
$child_ids = array_values($menu_link_manager
->getChildIds($menu_plugin_id));
sort($expected_item['children']);
if ($child_ids) {
sort($child_ids);
}
$this
->assertSame($expected_item['children'], $child_ids);
unset($expected_item['children']);
}
if (isset($expected_item['parents'])) {
$parent_ids = array_values($menu_link_manager
->getParentIds($menu_plugin_id));
$this
->assertSame($expected_item['parents'], $parent_ids);
unset($expected_item['parents']);
}
if (isset($expected_item['langcode']) && $entity) {
$this
->assertEquals($expected_item['langcode'], $entity->langcode->value);
unset($expected_item['langcode']);
}
if (isset($expected_item['enabled']) && $entity) {
$this
->assertEquals($expected_item['enabled'], $entity->enabled->value);
unset($expected_item['enabled']);
}
foreach ($expected_item as $key => $value) {
$this
->assertNotNull($definition[$key]);
$this
->assertSame($value, $definition[$key]);
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
MenuUiTrait:: |
protected | function | Asserts that a menu fetched from the database matches an expected one. |