/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
/* globals getTestActorWithoutToolbox */
"use strict";
// Test that locking the pseudoclass displays correctly in the ruleview
const PSEUDO = ":hover";
const TEST_URL =
"data:text/html;charset=UTF-8," +
"
" +
" " +
"" +
"" +
' ' +
'
test div
' +
'
test div2
' +
"
" +
"";
add_task(async function() {
info("Creating the test tab and opening the rule-view");
let { toolbox, inspector, testActor } = await openInspectorForURL(TEST_URL);
info("Selecting the ruleview sidebar");
inspector.sidebar.select("ruleview");
const view = inspector.getPanel("ruleview").view;
info("Selecting the test node");
await selectNode("#div-1", inspector);
await togglePseudoClass(inspector);
await assertPseudoAddedToNode(inspector, testActor, view, "#div-1");
await togglePseudoClass(inspector);
await assertPseudoRemovedFromNode(testActor, "#div-1");
await assertPseudoRemovedFromView(inspector, testActor, view, "#div-1");
await togglePseudoClass(inspector);
await testNavigate(inspector, testActor, view);
info("Toggle pseudo on the parent and ensure everything is toggled off");
await selectNode("#parent-div", inspector);
await togglePseudoClass(inspector);
await assertPseudoRemovedFromNode(testActor, "#div-1");
await assertPseudoRemovedFromView(inspector, testActor, view, "#div-1");
await togglePseudoClass(inspector);
info("Assert pseudo is dismissed when toggling it on a sibling node");
await selectNode("#div-2", inspector);
await togglePseudoClass(inspector);
await assertPseudoAddedToNode(inspector, testActor, view, "#div-2");
const hasLock = await testActor.hasPseudoClassLock("#div-1", PSEUDO);
ok(
!hasLock,
"pseudo-class lock has been removed for the previous locked node"
);
info("Destroying the toolbox");
const tab = toolbox.target.localTab;
await toolbox.destroy();
// As the toolbox get destroyed, we need to fetch a new test-actor
testActor = await getTestActorWithoutToolbox(tab);
await assertPseudoRemovedFromNode(testActor, "#div-1");
await assertPseudoRemovedFromNode(testActor, "#div-2");
});
async function togglePseudoClass(inspector) {
info("Toggle the pseudoclass, wait for it to be applied");
// Give the inspector panels a chance to update when the pseudoclass changes
const onPseudo = inspector.selection.once("pseudoclass");
const onRefresh = inspector.once("rule-view-refreshed");
// Walker uses SDK-events so calling walker.once does not return a promise.
const onMutations = once(inspector.walker, "mutations");
await inspector.togglePseudoClass(PSEUDO);
await onPseudo;
await onRefresh;
await onMutations;
}
async function testNavigate(inspector, testActor, ruleview) {
await selectNode("#parent-div", inspector);
info("Make sure the pseudoclass is still on after navigating to a parent");
ok(
await testActor.hasPseudoClassLock("#div-1", PSEUDO),
"pseudo-class lock is still applied after inspecting ancestor"
);
await selectNode("#div-2", inspector);
info(
"Make sure the pseudoclass is still set after navigating to a " +
"non-hierarchy node"
);
ok(
await testActor.hasPseudoClassLock("#div-1", PSEUDO),
"pseudo-class lock is still on after inspecting sibling node"
);
await selectNode("#div-1", inspector);
}
async function assertPseudoAddedToNode(
inspector,
testActor,
ruleview,
selector
) {
info(
"Make sure the pseudoclass lock is applied to " +
selector +
" and its ancestors"
);
let hasLock = await testActor.hasPseudoClassLock(selector, PSEUDO);
ok(hasLock, "pseudo-class lock has been applied");
hasLock = await testActor.hasPseudoClassLock("#parent-div", PSEUDO);
ok(hasLock, "pseudo-class lock has been applied");
hasLock = await testActor.hasPseudoClassLock("body", PSEUDO);
ok(hasLock, "pseudo-class lock has been applied");
info("Check that the ruleview contains the pseudo-class rule");
const rules = ruleview.element.querySelectorAll(".ruleview-rule");
is(
rules.length,
3,
"rule view is showing 3 rules for pseudo-class locked div"
);
is(
rules[1]._ruleEditor.rule.selectorText,
"div:hover",
"rule view is showing " + PSEUDO + " rule"
);
info("Show the highlighter on " + selector);
const nodeFront = await getNodeFront(selector, inspector);
await inspector.highlighters.showHighlighterTypeForNode(
inspector.highlighters.TYPES.BOXMODEL,
nodeFront
);
info("Check that the infobar selector contains the pseudo-class");
const value = await testActor.getHighlighterNodeTextContent(
"box-model-infobar-pseudo-classes"
);
is(value, PSEUDO, "pseudo-class in infobar selector");
await inspector.highlighters.hideHighlighterType(
inspector.highlighters.TYPES.BOXMODEL
);
}
async function assertPseudoRemovedFromNode(testActor, selector) {
info(
"Make sure the pseudoclass lock is removed from #div-1 and its " +
"ancestors"
);
let hasLock = await testActor.hasPseudoClassLock(selector, PSEUDO);
ok(!hasLock, "pseudo-class lock has been removed");
hasLock = await testActor.hasPseudoClassLock("#parent-div", PSEUDO);
ok(!hasLock, "pseudo-class lock has been removed");
hasLock = await testActor.hasPseudoClassLock("body", PSEUDO);
ok(!hasLock, "pseudo-class lock has been removed");
}
async function assertPseudoRemovedFromView(
inspector,
testActor,
ruleview,
selector
) {
info("Check that the ruleview no longer contains the pseudo-class rule");
const rules = ruleview.element.querySelectorAll(".ruleview-rule");
is(rules.length, 2, "rule view is showing 2 rules after removing lock");
const nodeFront = await getNodeFront(selector, inspector);
await inspector.highlighters.showHighlighterTypeForNode(
inspector.highlighters.TYPES.BOXMODEL,
nodeFront
);
const value = await testActor.getHighlighterNodeTextContent(
"box-model-infobar-pseudo-classes"
);
is(value, "", "pseudo-class removed from infobar selector");
await inspector.highlighters.hideHighlighterType(
inspector.highlighters.TYPES.BOXMODEL
);
}