Wed, 31 Dec 2014 06:09:35 +0100
Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.
1 <!DOCTYPE HTML>
2 <html>
3 <!--
4 https://bugzilla.mozilla.org/show_bug.cgi?id=558663
5 -->
6 <head>
7 <title>Test for Bug 558663</title>
8 <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
9 <script type="application/javascript" src="/tests/SimpleTest/EventUtils.js"></script>
10 <script type="application/javascript" src="/tests/SimpleTest/WindowSnapshot.js"></script>
11 <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
12 </head>
13 <body>
14 <p><a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=558663">Mozilla Bug 514127</a></p>
16 <!-- 20x20 of red -->
17 <iframe id="iframe" src="data:text/html,<img id='image' border='0' src='%2BYKJA76jmUc2jmkc1U0EzACKcASfOgGoMAAAAAElFTkSuQmCC'>"></iframe>
19 <pre id="test">
20 <script type="application/javascript">
22 /** Test for Bug 558663 **/
24 SimpleTest.waitForExplicitFinish();
25 window.addEventListener("load", runTest, false);
27 function checkSnapshots(s1, s2, shouldBeEqual, testName) {
28 var res = compareSnapshots(s1, s2, shouldBeEqual);
29 if (res[0]) {
30 ok(true, testName + " snapshots compare correctly");
31 } else {
32 ok(false, testName + " snapshots compare incorrectly. snapshot 1: " +
33 res[1] + " snapshot 2: " + res[2]);
34 }
35 }
37 function runTest() {
38 document.getElementById("iframe").contentWindow.document.designMode = "on";
40 // The editor requires the event loop to spin after you turn on design mode
41 // before it takes effect.
42 setTimeout(continueTest, 100);
43 }
45 function continueTest() {
46 var win = document.getElementById("iframe").contentWindow;
47 var doc = win.document;
48 var image = doc.getElementById("image");
50 // We want to test that clicking on the image and then clicking on one of the
51 // draggers doesn't make the draggers disappear.
53 // clean snapshot
54 var before = snapshotWindow(win);
56 // click to get the draggers
57 synthesizeMouse(image, 1, 1, {type: "mousedown"}, win);
58 synthesizeMouse(image, 1, 1, {type: "mouseup"}, win);
60 // mouse over a dragger will change its color, so move the mouse away
61 synthesizeMouse(doc.documentElement, 50, 50, {type: "mousemove"}, win);
63 // snapshot with hopefully draggers
64 var middle = snapshotWindow(win);
66 // clicking on the top left dragger shouldn't change anything
67 synthesizeMouse(image, 1, 1, {type: "mousedown"}, win);
68 synthesizeMouse(image, 1, 1, {type: "mouseup"}, win);
70 // mouse over a dragger will change its color, so move the mouse away
71 synthesizeMouse(doc.documentElement, 50, 50, {type: "mousemove"}, win);
73 // snapshot with hopefully draggers again
74 var middle2 = snapshotWindow(win);
76 // click outside the image (but inside the document) to unselect it
77 synthesizeMouse(doc.documentElement, 50, 50, {type: "mousedown"}, win);
78 synthesizeMouse(doc.documentElement, 50, 50, {type: "mouseup"}, win);
80 // and then click outside the document so we don't draw a caret
81 synthesizeMouse(document.documentElement, 1, 1, {type: "mousedown"}, window);
82 synthesizeMouse(document.documentElement, 1, 1, {type: "mouseup"}, window);
84 // hopefully clean snapshot
85 var end = snapshotWindow(win);
87 // before == end && middle == middle2 && before/end != middle/middle2
88 checkSnapshots(before, end, true, "before and after should be the same")
89 checkSnapshots(middle, middle2, true, "middle two should be the same");
90 checkSnapshots(before, middle, false, "before and middle should not be the same");
91 checkSnapshots(before, middle2, false, "before and middle2 should not be the same");
92 checkSnapshots(middle, end, false, "middle and end should not be the same");
93 checkSnapshots(middle2, end, false, "middle2 and end should not be the same");
95 SimpleTest.finish();
96 }
98 </script>
99 </pre>
100 </body>
101 </html>