diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /devtools/client/inspector/markup/test/browser_markup_keybindings_04.js | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r-- | devtools/client/inspector/markup/test/browser_markup_keybindings_04.js | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/devtools/client/inspector/markup/test/browser_markup_keybindings_04.js b/devtools/client/inspector/markup/test/browser_markup_keybindings_04.js new file mode 100644 index 0000000000..078fc571a8 --- /dev/null +++ b/devtools/client/inspector/markup/test/browser_markup_keybindings_04.js @@ -0,0 +1,71 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +requestLongerTimeout(2); + +// Tests that selecting a node using the browser context menu (inspect element) +// or the element picker focuses that node so that the keyboard can be used +// immediately. + +const TEST_URL = "data:text/html;charset=utf8,<div>test element</div>"; + +add_task(async function () { + const { inspector } = await openInspectorForURL(TEST_URL); + + info("Select the test node with the browser ctx menu"); + await clickOnInspectMenuItem("div"); + assertNodeSelected(inspector, "div"); + + info( + "Press arrowUp to focus <body> " + + "(which works if the node was focused properly)" + ); + await selectPreviousNodeWithArrowUp(inspector); + assertNodeSelected(inspector, "body"); + + info("Select the test node with the element picker"); + await selectWithElementPicker(inspector); + assertNodeSelected(inspector, "div"); + + info( + "Press arrowUp to focus <body> " + + "(which works if the node was focused properly)" + ); + await selectPreviousNodeWithArrowUp(inspector); + assertNodeSelected(inspector, "body"); +}); + +function assertNodeSelected(inspector, tagName) { + is( + inspector.selection.nodeFront.tagName.toLowerCase(), + tagName, + `The <${tagName}> node is selected` + ); +} + +function selectPreviousNodeWithArrowUp(inspector) { + const { waitForHighlighterTypeShown } = getHighlighterTestHelpers(inspector); + const onNodeHighlighted = waitForHighlighterTypeShown( + inspector.highlighters.TYPES.BOXMODEL + ); + const onUpdated = inspector.once("inspector-updated"); + EventUtils.synthesizeKey("KEY_ArrowUp"); + return Promise.all([onUpdated, onNodeHighlighted]); +} + +async function selectWithElementPicker(inspector) { + await startPicker(inspector.toolbox); + + await safeSynthesizeMouseEventAtCenterInContentPage( + "div", + { + type: "mousemove", + }, + gBrowser.selectedBrowser + ); + + BrowserTestUtils.synthesizeKey("KEY_Enter", {}, gBrowser.selectedBrowser); + await inspector.once("inspector-updated"); +} |