material-web/menu/harness.ts

51 lines
1.2 KiB
TypeScript
Raw Normal View History

/**
* @license
* Copyright 2022 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import {LitElement} from 'lit';
import {Harness} from '../testing/harness.js';
import {Menu} from './internal/menu.js';
import {MenuItemHarness} from './internal/menuitem/harness.js';
export {MenuItemHarness} from './internal/menuitem/harness.js';
/**
* Test harness for menu.
*/
export class MenuHarness extends Harness<Menu> {
/**
* Shows the menu and returns the first list item element.
*/
protected override async getInteractiveElement() {
await this.element.updateComplete;
return this.element.renderRoot.querySelector('md-list')!.renderRoot
.querySelector('.list') as HTMLElement;
}
/** @return ListItem harnesses for the menu's items. */
getItems() {
return this.element.items.map(
(item) => new MenuItemHarness(item as typeof item&LitElement));
}
async show() {
const menu = this.element;
if (menu.open) {
return;
}
const opened = new Promise((resolve) => {
menu.addEventListener('opened', () => {
resolve(true);
}, {once: true});
});
menu.show();
await opened;
}
}