layout/style/test/test_bug98997.html

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/layout/style/test/test_bug98997.html	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,144 @@
     1.4 +<!DOCTYPE HTML>
     1.5 +<html>
     1.6 +<!--
     1.7 +https://bugzilla.mozilla.org/show_bug.cgi?id=98997
     1.8 +-->
     1.9 +<head>
    1.10 +  <title>Test for Bug 98997</title>
    1.11 +  <script type="text/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
    1.12 +  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
    1.13 +  <style type="text/css">
    1.14 +
    1.15 +  /*
    1.16 +   * This test does NOT test any of the cases where :empty and
    1.17 +   * :-moz-only-whitespace differ.  We should probably have some tests
    1.18 +   * for that as well.
    1.19 +   */
    1.20 +  div.test { width: 200px; height: 30px; margin: 5px 0; }
    1.21 +  div.test.to, div.test.from:empty { background: orange; }
    1.22 +  div.test.to:empty, div.test.from { background: green; }
    1.23 +  div.test.to, div.test.from:-moz-only-whitespace { color: maroon; }
    1.24 +  div.test.to:-moz-only-whitespace, div.test.from { color: navy; }
    1.25 +
    1.26 +  </style>
    1.27 +</head>
    1.28 +<body>
    1.29 +<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=98997">Mozilla Bug 98997</a>
    1.30 +<div id="display">
    1.31 +<div class="test to" onclick="testReplaceChild(this, '')">x</div>
    1.32 +<div class="test to" onclick="testReplaceChild(this, '')"><span>x</span></div>
    1.33 +<div class="test to" onclick="testReplaceChild(this, '')">x<!-- comment --></div>
    1.34 +<div class="test to" onclick="testRemoveChild(this)">x</div>
    1.35 +<div class="test to" onclick="testRemoveChild(this)"><span>x</span></div>
    1.36 +<div class="test to" onclick="testRemoveChild(this)">x<!-- comment --></div>
    1.37 +<div class="test to" onclick="testChangeData(this, '')">x</div>
    1.38 +<div class="test to" onclick="testChangeData(this, '')">x<!-- comment --></div>
    1.39 +<div class="test to" onclick="testDeleteData(this)">x</div>
    1.40 +<div class="test to" onclick="testDeleteData(this)">x<!-- comment --></div>
    1.41 +<div class="test to" onclick="testReplaceData(this, '')">x</div>
    1.42 +<div class="test to" onclick="testReplaceData(this, '')">x<!-- comment --></div>
    1.43 +
    1.44 +<div class="test from makeemptytext" onclick="testReplaceChild(this, 'x')"></div>
    1.45 +<div class="test from makeemptytext" onclick="testReplaceChild(this, 'x')"><!-- comment --></div>
    1.46 +<div class="test from" onclick="testReplaceChild(this, 'x')"><!-- comment --></div>
    1.47 +<div class="test from" onclick="testInsertBefore(this, 'x')"></div>
    1.48 +<div class="test from" onclick="testInsertBefore(this, 'x')"><!-- comment --></div>
    1.49 +<div class="test from" onclick="testAppendChild(this, 'x')"></div>
    1.50 +<div class="test from" onclick="testAppendChild(this, 'x')"><!-- comment --></div>
    1.51 +<div class="test from makeemptytext" onclick="testChangeData(this, 'x')"></div>
    1.52 +<div class="test from makeemptytext" onclick="testChangeData(this, 'x')"><!-- comment --></div>
    1.53 +<div class="test from makeemptytext" onclick="testAppendData(this, 'x')"></div>
    1.54 +<div class="test from makeemptytext" onclick="testAppendData(this, 'x')"><!-- comment --></div>
    1.55 +<div class="test from makeemptytext" onclick="testReplaceData(this, 'x')"></div>
    1.56 +<div class="test from makeemptytext" onclick="testReplaceData(this, 'x')"><!-- comment --></div>
    1.57 +</div>
    1.58 +
    1.59 +<div id="content" style="display: none">
    1.60 +  
    1.61 +</div>
    1.62 +<pre id="test">
    1.63 +<script class="testbody" type="text/javascript">
    1.64 +
    1.65 +/** Test for Bug 98997 **/
    1.66 +
    1.67 +function testInsertBefore(elt, text) {
    1.68 +  elt.insertBefore(document.createTextNode(text), elt.firstChild);
    1.69 +}
    1.70 +
    1.71 +function testAppendChild(elt, text) {
    1.72 +  elt.appendChild(document.createTextNode(text));
    1.73 +}
    1.74 +
    1.75 +function testReplaceChild(elt, text) {
    1.76 +  elt.replaceChild(document.createTextNode(text), elt.firstChild);
    1.77 +}
    1.78 +
    1.79 +function testRemoveChild(elt) {
    1.80 +  elt.removeChild(elt.firstChild);
    1.81 +}
    1.82 +
    1.83 +function testChangeData(elt, text) {
    1.84 +  elt.firstChild.data = text;
    1.85 +}
    1.86 +
    1.87 +function testAppendData(elt, text) {
    1.88 +  elt.firstChild.appendData(text);
    1.89 +}
    1.90 +
    1.91 +function testDeleteData(elt) {
    1.92 +  elt.firstChild.deleteData(0, elt.firstChild.length);
    1.93 +}
    1.94 +
    1.95 +function testReplaceData(elt, text) {
    1.96 +  elt.firstChild.replaceData(0, elt.firstChild.length, text);
    1.97 +}
    1.98 +
    1.99 +var cnodes = document.getElementById("display").childNodes;
   1.100 +var divs = [];
   1.101 +var i;
   1.102 +for (i = 0; i < cnodes.length; ++i) {
   1.103 +  if (cnodes[i].nodeName == "DIV")
   1.104 +    divs.push(cnodes[i]);
   1.105 +}
   1.106 +
   1.107 +for (i in divs) {
   1.108 +  var div = divs[i];
   1.109 +  if (div.className.match(/makeemptytext/))
   1.110 +    div.insertBefore(document.createTextNode(""), div.firstChild);
   1.111 +}
   1.112 +
   1.113 +const ORANGE = "rgb(255, 165, 0)";
   1.114 +const MAROON = "rgb(128, 0, 0)";
   1.115 +const GREEN = "rgb(0, 128, 0)";
   1.116 +const NAVY = "rgb(0, 0, 128)";
   1.117 +
   1.118 +function color(div) {
   1.119 +  return getComputedStyle(div, "").color;
   1.120 +}
   1.121 +function bg(div) {
   1.122 +  return getComputedStyle(div, "").backgroundColor;
   1.123 +}
   1.124 +
   1.125 +for (i in divs) {
   1.126 +  var div = divs[i];
   1.127 +  is(bg(div), ORANGE, "should be orange");
   1.128 +  is(color(div), MAROON, "should be maroon");
   1.129 +}
   1.130 +
   1.131 +for (i in divs) {
   1.132 +  var div = divs[i];
   1.133 +  var e = document.createEvent("MouseEvents");
   1.134 +  e.initEvent("click", true, true);
   1.135 +  div.dispatchEvent(e);
   1.136 +}
   1.137 +
   1.138 +for (i in divs) {
   1.139 +  var div = divs[i];
   1.140 +  is(bg(div), GREEN, "should be green");
   1.141 +  is(color(div), NAVY, "should be navy");
   1.142 +}
   1.143 +
   1.144 +</script>
   1.145 +</pre>
   1.146 +</body>
   1.147 +</html>

mercurial