Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
"use strict";
// Test that the node picker can pick elements with pointer-events: none when holding Shift.
const TEST_URI = `data:text/html;charset=utf-8,
<!DOCTYPE html>
<main style="display:flex; margin-top: 100px;">
<div id="pointer">Regular element</div>
<-- ⚠️ Make the element overlap with its parent so assertHighlightedNode can be used -->
<div id="nopointer" style="pointer-events: none;translate: 0 -10%; outline: 1px solid">Element with pointer-events: none</div>
<div id="transluscent" style="pointer-events: none;opacity: 0.1">Element with opacity of 0.1</div>
<div id="invisible" style="pointer-events: none;opacity: 0">Element with opacity of 0</div>
<div>
<header>Hello</header>
<div style="z-index:-1;position:relative;">
<span id="negative-z-index-child">ZZ</span>
</div>
</div>
</main>`;
const IS_OSX = Services.appinfo.OS === "Darwin";
add_task(async function () {
const { inspector, toolbox, highlighterTestFront } =
await openInspectorForURL(TEST_URI);
const body = await getNodeFront("body", inspector);
is(
inspector.selection.nodeFront,
body,
"By default the body node is selected"
);
info("Start the element picker");
await startPicker(toolbox);
info(
"Shift-clicking element with pointer-events: none does select the element"
);
await clickElement({
inspector,
selector: "#nopointer",
shiftKey: true,
});
await checkElementSelected("#nopointer", inspector);
info("Shift-clicking element with default pointer-events value also works");
await clickElement({
inspector,
selector: "#pointer",
shiftKey: true,
});
await checkElementSelected("#pointer", inspector);
info(
"Clicking element with pointer-events: none without holding Shift won't select the element but its parent"
);
await clickElement({
inspector,
selector: "#nopointer",
shiftKey: false,
});
await checkElementSelected("main", inspector);
info("Shift-clicking transluscent visible element works");
await clickElement({
inspector,
selector: "#transluscent",
shiftKey: true,
});
await checkElementSelected("#transluscent", inspector);
info("Shift-clicking invisible element select its parent");
await clickElement({
inspector,
selector: "#invisible",
shiftKey: true,
});
await checkElementSelected("main", inspector);
info("Shift-clicking element with negative z-index parent works");
await hoverElement(
inspector,
"#negative-z-index-child",
undefined,
undefined,
{
shiftKey: true,
}
);
is(
await highlighterTestFront.getHighlighterNodeTextContent(
"box-model-infobar-id"
),
"#negative-z-index-child",
"The highlighter is shown on #negative-z-index-child"
);
await clickElement({
inspector,
selector: "#negative-z-index-child",
shiftKey: true,
});
await checkElementSelected("#negative-z-index-child", inspector);
info("Hover pointer-events element without holding Shift");
await hoverElement(inspector, "#nopointer");
ok(
await highlighterTestFront.assertHighlightedNode("main"),
"The highlighter is shown on the expected node"
);
info("Pressing Shift should highlight the pointer-events element");
let onHovered = inspector.toolbox.nodePicker.once("picker-node-hovered");
await BrowserTestUtils.synthesizeKey(
"VK_SHIFT",
{ type: "keydown" },
gBrowser.selectedBrowser
);
await onHovered;
ok(true, "Got a picker-node-hovered event when pressing shift");
ok(
await highlighterTestFront.assertHighlightedNode("#nopointer"),
"The highlighter is shown on the expected node"
);
info("Releasing Shift should unhighlight the pointer-events element");
onHovered = inspector.toolbox.nodePicker.once("picker-node-hovered");
await BrowserTestUtils.synthesizeKey(
"VK_SHIFT",
{ type: "keyup" },
gBrowser.selectedBrowser
);
await onHovered;
ok(true, "Got a picker-node-hovered event when releasing shift");
ok(
await highlighterTestFront.assertHighlightedNode("main"),
"The highlighter is shown on the expected node"
);
});
async function clickElement({ selector, inspector, shiftKey }) {
const onSelectionChanged = inspector.once("inspector-updated");
await safeSynthesizeMouseEventAtCenterInContentPage(selector, {
shiftKey,
// Hold meta/ctrl so we don't have to start the picker again
[IS_OSX ? "metaKey" : "ctrlKey"]: true,
});
await onSelectionChanged;
}
async function checkElementSelected(selector, inspector) {
const el = await getNodeFront(selector, inspector);
is(
inspector.selection.nodeFront,
el,
`The element ${selector} is now selected`
);
}