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 +