mirror of
https://github.com/microsoft/vscode.git
synced 2026-04-20 16:49:06 +01:00
One common source of flakiness is just dispatching a keybinding and not verifying it did its thing. This change adds a few accept functions and also forces callers to provide an async function so that the caller considers adding one as it's the norm, not the edge case. Fixes #246731
60 lines
2.5 KiB
TypeScript
60 lines
2.5 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import { Code } from './code';
|
|
|
|
export class QuickInput {
|
|
|
|
private static QUICK_INPUT = '.quick-input-widget';
|
|
private static QUICK_INPUT_INPUT = `${QuickInput.QUICK_INPUT} .quick-input-box input`;
|
|
private static QUICK_INPUT_ROW = `${QuickInput.QUICK_INPUT} .quick-input-list .monaco-list-row`;
|
|
private static QUICK_INPUT_FOCUSED_ELEMENT = `${QuickInput.QUICK_INPUT_ROW}.focused .monaco-highlighted-label`;
|
|
// Note: this only grabs the label and not the description or detail
|
|
private static QUICK_INPUT_ENTRY_LABEL = `${QuickInput.QUICK_INPUT_ROW} .quick-input-list-row > .monaco-icon-label .label-name`;
|
|
private static QUICK_INPUT_ENTRY_LABEL_SPAN = `${QuickInput.QUICK_INPUT_ROW} .monaco-highlighted-label`;
|
|
|
|
constructor(private code: Code) { }
|
|
|
|
async waitForQuickInputOpened(retryCount?: number): Promise<void> {
|
|
await this.code.waitForActiveElement(QuickInput.QUICK_INPUT_INPUT, retryCount);
|
|
}
|
|
|
|
async type(value: string): Promise<void> {
|
|
await this.code.waitForSetValue(QuickInput.QUICK_INPUT_INPUT, value);
|
|
}
|
|
|
|
async waitForQuickInputElementFocused(): Promise<void> {
|
|
await this.code.waitForTextContent(QuickInput.QUICK_INPUT_FOCUSED_ELEMENT);
|
|
}
|
|
|
|
async waitForQuickInputElementText(): Promise<string> {
|
|
return this.code.waitForTextContent(QuickInput.QUICK_INPUT_ENTRY_LABEL_SPAN);
|
|
}
|
|
|
|
async closeQuickInput(): Promise<void> {
|
|
await this.code.dispatchKeybinding('escape', () => this.waitForQuickInputClosed());
|
|
}
|
|
|
|
async waitForQuickInputElements(accept: (names: string[]) => boolean): Promise<void> {
|
|
await this.code.waitForElements(QuickInput.QUICK_INPUT_ENTRY_LABEL, false, els => accept(els.map(e => e.textContent)));
|
|
}
|
|
|
|
async waitForQuickInputClosed(): Promise<void> {
|
|
await this.code.waitForElement(QuickInput.QUICK_INPUT, r => !!r && r.attributes.style.indexOf('display: none;') !== -1);
|
|
}
|
|
|
|
async selectQuickInputElement(index: number, keepOpen?: boolean): Promise<void> {
|
|
await this.waitForQuickInputOpened();
|
|
for (let from = 0; from < index; from++) {
|
|
await this.code.dispatchKeybinding('down', async () => { });
|
|
}
|
|
await this.code.dispatchKeybinding('enter', async () => {
|
|
if (!keepOpen) {
|
|
await this.waitForQuickInputClosed();
|
|
}
|
|
});
|
|
}
|
|
}
|