summaryrefslogtreecommitdiffstats
path: root/devtools/client/inspector/rules/test/browser_rules_mark_overridden_01.js
blob: ab10fadfe9d965ccd8bfe6479ce4cc8a27b9fe53 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
/* 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 = `
  <style type='text/css'>
  #testid {
    background-color: blue;
  }
  .testclass {
    background-color: green;
  }
  </style>
  <div id='testid' class='testclass'>Styled Node</div>
`;

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");
});