/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
// Tests that the scrollable badge is shown next to scrollable elements, and is updated
// dynamically when necessary.
const TEST_URI = `
`;
add_task(async function () {
const { inspector } = await openInspectorForURL(
"data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI)
);
let badge = await getBadgeEl(inspector);
ok(badge, "The scrollable badge exists on the test node");
info("Make the test node non-scrollable");
let onStateChanged = inspector.walker.once("scrollable-change");
await toggleScrollableClass();
await onStateChanged;
badge = await getBadgeEl(inspector);
ok(!badge, "The scrollable badge doesn't exist anymore");
info("Make the test node scrollable again");
onStateChanged = inspector.walker.once("scrollable-change");
await toggleScrollableClass();
await onStateChanged;
badge = await getBadgeEl(inspector);
ok(badge, "The scrollable badge exists again");
});
async function getBadgeEl(inspector) {
const wrapperMarkupContainer = await getContainerForSelector(
"#wrapper",
inspector
);
return wrapperMarkupContainer.elt.querySelector(
".inspector-badge.scrollable-badge"
);
}
async function toggleScrollableClass() {
await SpecialPowers.spawn(gBrowser.selectedBrowser, [], async function () {
content.document.querySelector("#wrapper").classList.toggle("no-scroll");
});
}