/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
"use strict";
// Tests that the rule view marks overridden rules correctly based on the
// specificity of the rule.
const TEST_URI = `
Styled Node
`;
add_task(function* () {
yield addTab("data:text/html;charset=utf-8," + encodeURIComponent(TEST_URI));
let {inspector, view} = yield openRuleView();
yield selectNode("#testid", inspector);
let idRule = getRuleViewRuleEditor(view, 1).rule;
let idProp = idRule.textProps[0];
is(idProp.name, "background-color",
"First ID property should be background-color");
is(idProp.value, "blue", "First ID property value should be blue");
ok(!idProp.overridden, "ID prop should not be overridden.");
ok(!idProp.editor.element.classList.contains("ruleview-overridden"),
"ID property editor should not have ruleview-overridden class");
let classRule = getRuleViewRuleEditor(view, 2).rule;
let classProp = classRule.textProps[0];
is(classProp.name, "background-color",
"First class prop should be background-color");
is(classProp.value, "green", "First class property value should be green");
ok(classProp.overridden, "Class property should be overridden.");
ok(classProp.editor.element.classList.contains("ruleview-overridden"),
"Class property editor should have ruleview-overridden class");
// Override background-color by changing the element style.
let elementProp = yield addProperty(view, 0, "background-color", "purple");
ok(!elementProp.overridden,
"Element style property should not be overridden");
ok(idProp.overridden, "ID property should be overridden");
ok(idProp.editor.element.classList.contains("ruleview-overridden"),
"ID property editor should have ruleview-overridden class");
ok(classProp.overridden, "Class property should be overridden");
ok(classProp.editor.element.classList.contains("ruleview-overridden"),
"Class property editor should have ruleview-overridden class");
});