summaryrefslogtreecommitdiffstats
path: root/layout/style/test/test_bug413958.html
blob: 0b48e3aa68a8163f3531dfc06365a3f59aa7d75f (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
<!doctype html>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=413958
-->
<head>
  <title>Test for Bug 413958</title>
  <meta charset="UTF-8">
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" href="/tests/SimpleTest/test.css">
</head>
<body>
<style>span { color: red }</style><!-- backstop -->
<p><a target="_blank"
      href="https://bugzilla.mozilla.org/show_bug.cgi?id=413958"
      >Mozilla Bug 413958</a>. All text below should be black on white.</p>
<p>Sheet: <span id="s1">1</span>
          <span id="s2">2</span>
          <span id="s3">3</span>.
   Style attr: <span id="setStyle">4</span>.
   Properties: <span id="setStyleProp" style="">5</span>.</p>
<script>
SpecialPowers.wrap(window).docShell.cssErrorReportingEnabled = true;

var tests = [
  function() {
    var s = document.createTextNode(
"#s1{nosuchprop:auto; color:black}\n"+
"#s2{nosuchprop:auto; color:black}invalid?sel{}#s3{color:black}"),
        e = document.createElement("style");
    e.appendChild(s);
    document.body.appendChild(e);
  },
  function() {
    document.getElementById("setStyle")
            .setAttribute("style", "width:200;color:black");
  },
  function() {
    var s = document.getElementById("setStyleProp").style;
    s.width = "200";
    s.color = "black";
  },
];
var results = [
  [ { errorMessage: /Unknown property \u2018nosuchprop\u2019/,
      lineNumber: 1, columnNumber: 16, sourceLine: "", cssSelectors: "#s1" },
    { errorMessage: /Unknown property \u2018nosuchprop\u2019/,
      lineNumber: 2, columnNumber: 16, sourceLine: "", cssSelectors: "#s2" },
    { errorMessage: /Ruleset ignored due to bad selector/,
      lineNumber: 2, columnNumber: 41, sourceLine: "", cssSelectors: "" } ],
  [ { errorMessage: /parsing value for \u2018width\u2019/,
      lineNumber: 1, columnNumber: 7, sourceLine: "", cssSelectors: "" } ],
  [ { errorMessage: /parsing value for \u2018width\u2019/,
      lineNumber: 1, columnNumber: 1, sourceLine: "", cssSelectors: "" } ],
];
var curTest = -1;

function doTest() {
  if (++curTest == tests.length) {
    var ss = document.getElementsByTagName("span");
    for (var i = 0; i < ss.length; i++) {
      is(window.getComputedStyle(ss[i]).color, "rgb(0, 0, 0)",
         "recovery | " + ss[i].id);
    }
    SimpleTest.finish();
  } else {
    SimpleTest.expectConsoleMessages(tests[curTest], results[curTest], doTest);
  }
}

SimpleTest.waitForExplicitFinish();
doTest();
</script>
</body>
</html>