summaryrefslogtreecommitdiffstats
path: root/layout/style/test/chrome/test_stylesheet_clone_import_rule.html
blob: ce2bef8016eeab0861d70b9108fab25049acdc9f (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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<!DOCTYPE html>
<html lang="en-US">
<script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" type="text/css" href="chrome://mochikit/content/tests/SimpleTest/test.css"/>

<style>div { color: green; }</style>

<link id="theOnlyLink" rel="stylesheet" type="text/css" href="import_useless1.css">

<div id="theOnlyDiv">This text will change colors several times.</div>

<script>
  SimpleTest.waitForExplicitFinish();

  const Cu = SpecialPowers.Components.utils;
  const { ContentTaskUtils } = ChromeUtils.import("resource://testing-common/ContentTaskUtils.jsm");

  let theOnlyDiv = document.getElementById("theOnlyDiv");
  let link = document.getElementById("theOnlyLink");
  let stylesheet = link.sheet;

  runTest().catch(function(reason) {
    ok(false, "Failed with reason: " + reason);
  }).then(function() {
    SimpleTest.finish();
  });

  function cssRulesToString(cssRules) {
    return Array.from(cssRules).map(rule => rule.cssText).join('');
  }

  async function runTest() {
    // Test that the div is initially red (from base.css)
    is(getComputedStyle(theOnlyDiv).color, "rgb(0, 128, 0)", "div begins as green.");

    // Insert some import rules.
    stylesheet.insertRule('@import url("import_useless2.css")', 0);
    stylesheet.insertRule('@import url("import_useless2.css")', 1);

    // Do some sanity checking of our import rules.
    let primaryRules = stylesheet.cssRules;
    await ContentTaskUtils.waitForCondition(function() {
      try {
        primaryRules[0].styleSheet.cssRules;
        primaryRules[1].styleSheet.cssRules;
        return true;
      } catch (ex) {
        return false;
      }
    });

    // Make some helper variables for the comparison tests.
    let importSheet1 = primaryRules[0].styleSheet;
    let rules1 = importSheet1.cssRules;

    let importSheet2 = primaryRules[1].styleSheet;
    let rules2 = importSheet2.cssRules;

    // Confirm that these two sheets are meaningfully the same.
    is(cssRulesToString(rules1), cssRulesToString(rules2), "Cloned sheet rules are equivalent.");

    // Add a color-changing rule to the first stylesheet.
    importSheet1.insertRule('div { color: blue; }');
    rules1 = importSheet1.cssRules;

    // And make sure that it has an effect.
    is(getComputedStyle(theOnlyDiv).color, "rgb(0, 0, 255)", "div becomes blue.");

    // Make sure that the two sheets have different rules now.
    isnot(cssRulesToString(rules1), cssRulesToString(rules2), "Cloned sheet rules are no longer equivalent.");

    // Add a color-changing rule to the second stylesheet (that will mask the first).
    importSheet2.insertRule('div { color: red; }');
    // And make sure that it has an effect.
    is(getComputedStyle(theOnlyDiv).color, "rgb(255, 0, 0)", "div becomes red.");

    // Delete the second sheet by removing the import rule, and make sure the color changes back.
    stylesheet.deleteRule(1);
    is(getComputedStyle(theOnlyDiv).color, "rgb(0, 0, 255)", "div goes back to blue.");

    // Delete the first sheet by removing the import rule, and make sure the color changes back.
    stylesheet.deleteRule(0);
    is(getComputedStyle(theOnlyDiv).color, "rgb(0, 128, 0)", "div goes back to green.");
  }
</script>
</html>