layout/style/test/test_bug357614.html

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/layout/style/test/test_bug357614.html	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,73 @@
     1.4 +<!DOCTYPE HTML>
     1.5 +<html>
     1.6 +<!--
     1.7 +https://bugzilla.mozilla.org/show_bug.cgi?id=357614
     1.8 +-->
     1.9 +<head>
    1.10 +  <title>Test for Bug 357614</title>
    1.11 +  <script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
    1.12 +  <style type="text/css" id="style">
    1.13 +  a { color: red; }
    1.14 +  a { color: green; }
    1.15 +  </style>
    1.16 +  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
    1.17 +</head>
    1.18 +<body>
    1.19 +<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=357614">Mozilla Bug 357614</a>
    1.20 +<p id="display"><a href="http://www.FOO.com/" rel="next" rev="PREV" foo="bar">a link</a></p>
    1.21 +<div id="content" style="display: none">
    1.22 +  
    1.23 +</div>
    1.24 +<pre id="test">
    1.25 +<script class="testbody" type="text/javascript">
    1.26 +
    1.27 +/** Test for Bug 357614 **/
    1.28 +
    1.29 +var sheet = document.getElementById("style").sheet;
    1.30 +var rule1 = sheet.cssRules[0];
    1.31 +var rule2 = sheet.cssRules[1];
    1.32 +
    1.33 +var a = document.getElementById("display").firstChild;
    1.34 +var cs = getComputedStyle(a, "");
    1.35 +
    1.36 +function change_selector_text(selector) {
    1.37 +  // rule2.selectorText = selector; // NOT IMPLEMENTED
    1.38 +
    1.39 +  sheet.deleteRule(1);
    1.40 +  sheet.insertRule(selector + " { color: green; }", 1);
    1.41 +}
    1.42 +
    1.43 +var cs_green = cs.getPropertyValue("color");
    1.44 +change_selector_text('p');
    1.45 +var cs_red = cs.getPropertyValue("color");
    1.46 +isnot(cs_green, cs_red, "computed values for green and red are different");
    1.47 +
    1.48 +change_selector_text('a[href="http://www.FOO.com/"]');
    1.49 +is(cs.getPropertyValue("color"), cs_green, "selector on href value matches case-sensitively");
    1.50 +
    1.51 +change_selector_text('a[href="http://www.foo.com/"]');
    1.52 +is(cs.getPropertyValue("color"), cs_red, "selector on href value does not match case-insensitively");
    1.53 +
    1.54 +change_selector_text('a[rel="next"]');
    1.55 +is(cs.getPropertyValue("color"), cs_green, "selector on rel value matches case-sensitively");
    1.56 +
    1.57 +change_selector_text('a[rel="NEXT"]');
    1.58 +is(cs.getPropertyValue("color"), cs_green, "selector on rel value matches case-insensitively");
    1.59 +
    1.60 +change_selector_text('a[rev="PREV"]');
    1.61 +is(cs.getPropertyValue("color"), cs_green, "selector on rev value matches case-sensitively");
    1.62 +
    1.63 +change_selector_text('a[rev="prev"]');
    1.64 +is(cs.getPropertyValue("color"), cs_green, "selector on rev value matches case-insensitively");
    1.65 +
    1.66 +change_selector_text('a[foo="bar"]');
    1.67 +is(cs.getPropertyValue("color"), cs_green, "selector on foo value matches case-sensitively");
    1.68 +
    1.69 +change_selector_text('a[foo="Bar"]');
    1.70 +is(cs.getPropertyValue("color"), cs_red, "selector on foo value does not match case-insensitively");
    1.71 +
    1.72 +</script>
    1.73 +</pre>
    1.74 +</body>
    1.75 +</html>
    1.76 +

mercurial