Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
/* Any copyright is dedicated to the Public Domain.
"use strict";
// Tests that the grid display badge toggles on the grid highlighter.
const TEST_URI = `
<style type="text/css">
#grid {
display: grid;
}
</style>
<div id="grid"></div>
`;
add_task(async function () {
await addTab("data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI));
const { inspector } = await openLayoutView();
const { highlighters, store } = inspector;
const HIGHLIGHTER_TYPE = inspector.highlighters.TYPES.GRID;
const { waitForHighlighterTypeShown, waitForHighlighterTypeHidden } =
getHighlighterTestHelpers(inspector);
info("Check the grid display badge is shown and not active.");
await selectNode("#grid", inspector);
const gridContainer = await getContainerForSelector("#grid", inspector);
const gridDisplayBadge = gridContainer.elt.querySelector(
".inspector-badge.interactive[data-display]"
);
ok(
!gridDisplayBadge.classList.contains("active"),
"grid display badge is not active."
);
ok(
gridDisplayBadge.classList.contains("interactive"),
"grid display badge is interactive."
);
info("Check the initial state of the grid highlighter.");
ok(
!highlighters.gridHighlighters.size,
"No CSS grid highlighter exists in the highlighters overlay."
);
info("Toggling ON the CSS grid highlighter from the grid display badge.");
const onHighlighterShown = waitForHighlighterTypeShown(HIGHLIGHTER_TYPE);
let onCheckboxChange = waitUntilState(
store,
state => state.grids.length === 1 && state.grids[0].highlighted
);
gridDisplayBadge.click();
await onHighlighterShown;
await onCheckboxChange;
info(
"Check that the CSS grid highlighter is created and the display badge state."
);
is(
highlighters.gridHighlighters.size,
1,
"CSS grid highlighter is created in the highlighters overlay."
);
ok(
gridDisplayBadge.classList.contains("active"),
"grid display badge is active."
);
ok(
gridDisplayBadge.classList.contains("interactive"),
"grid display badge is interactive."
);
info("Toggling OFF the CSS grid highlighter from the grid display badge.");
const onHighlighterHidden = waitForHighlighterTypeHidden(HIGHLIGHTER_TYPE);
onCheckboxChange = waitUntilState(
store,
state => state.grids.length == 1 && !state.grids[0].highlighted
);
gridDisplayBadge.click();
await onHighlighterHidden;
await onCheckboxChange;
ok(
!gridDisplayBadge.classList.contains("active"),
"grid display badge is not active."
);
ok(
gridDisplayBadge.classList.contains("interactive"),
"grid display badge is interactive."
);
});