1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/layout/base/tests/test_bug582771.html Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,128 @@ 1.4 +<!DOCTYPE HTML> 1.5 +<html> 1.6 +<!-- 1.7 +https://bugzilla.mozilla.org/show_bug.cgi?id=582771 1.8 +--> 1.9 +<head> 1.10 + <title>Test for Bug 582771</title> 1.11 + <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script> 1.12 + <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/> 1.13 + <style> 1.14 + .test { 1.15 + width: 20px; 1.16 + height: 20px; 1.17 + border: 1px solid black; 1.18 + -moz-user-select: none; 1.19 + } 1.20 + </style> 1.21 +</head> 1.22 +<body onload="setTimeout('runTest()', 0)"> 1.23 +<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=582771">Mozilla Bug 582771</a> 1.24 +<p id="display"></p> 1.25 +<div id="content" style="display: none"> 1.26 + 1.27 +</div> 1.28 +<pre id="test"> 1.29 +<script type="application/javascript"> 1.30 + 1.31 +/** Test for Bug 582771 **/ 1.32 + 1.33 +SimpleTest.waitForExplicitFinish(); 1.34 +var d1; 1.35 +var d2; 1.36 +var d1mousemovecount = 0; 1.37 +var d2mousemovecount = 0; 1.38 + 1.39 +function sendMouseMove(el) { 1.40 + var rect = el.getBoundingClientRect(); 1.41 + var utils = SpecialPowers.getDOMWindowUtils(window); 1.42 + utils.sendMouseEvent('mousemove', rect.left + 5, rect.top + 5, 0, 0, 0); 1.43 +} 1.44 + 1.45 +function sendMouseDown(el) { 1.46 + var rect = el.getBoundingClientRect(); 1.47 + var utils = SpecialPowers.getDOMWindowUtils(window); 1.48 + utils.sendMouseEvent('mousedown', rect.left + 5, rect.top + 5, 0, 1, 0); 1.49 +} 1.50 + 1.51 +function sendMouseUp(el) { 1.52 + var rect = el.getBoundingClientRect(); 1.53 + var utils = SpecialPowers.getDOMWindowUtils(window); 1.54 + utils.sendMouseEvent('mouseup', rect.left + 5, rect.top + 5, 0, 1, 0); 1.55 +} 1.56 + 1.57 +function log(s) { 1.58 + document.getElementById("l").textContent += s + "\n"; 1.59 +} 1.60 + 1.61 +function d2Listener(e) { 1.62 + log(e.type + ", " + e.target.id); 1.63 + is(e.target, d2, "d2 should have got mousemove."); 1.64 + ++d2mousemovecount; 1.65 +} 1.66 + 1.67 +function d1Listener(e) { 1.68 + log(e.type + ", " + e.target.id); 1.69 + d1.setCapture(true); 1.70 +} 1.71 + 1.72 +function d1Listener2(e) { 1.73 + log(e.type + ", " + e.target.id); 1.74 + d2.setCapture(true); 1.75 +} 1.76 + 1.77 +function d1MouseMoveListener(e) { 1.78 + log(e.type + ", " + e.target.id); 1.79 + ++d1mousemovecount; 1.80 +} 1.81 + 1.82 +function runTest() { 1.83 + d1 = document.getElementById("d1"); 1.84 + d2 = document.getElementById("d2"); 1.85 + d2.addEventListener("mousemove", d2Listener, true); 1.86 + document.body.offsetLeft; 1.87 + sendMouseMove(d2); 1.88 + is(d2mousemovecount, 1, "Should have got mousemove"); 1.89 + 1.90 + // This shouldn't enable capturing, since we're not in a right kind of 1.91 + // event listener. 1.92 + d1.setCapture(true); 1.93 + sendMouseDown(d1); 1.94 + sendMouseMove(d2); 1.95 + sendMouseUp(d1); 1.96 + is(d2mousemovecount, 2, "Should have got mousemove"); 1.97 + 1.98 + d1.addEventListener("mousedown", d1Listener, true); 1.99 + d1.addEventListener("mousemove", d1MouseMoveListener, true); 1.100 + sendMouseDown(d1); 1.101 + sendMouseMove(d2); 1.102 + is(d2mousemovecount, 2, "Shouldn't have got mousemove"); 1.103 + is(d1mousemovecount, 1, "Should have got mousemove"); 1.104 + sendMouseUp(d1); 1.105 + d1.removeEventListener("mousedown", d1Listener, true); 1.106 + d1.removeEventListener("mousemove", d1MouseMoveListener, true); 1.107 + 1.108 + // Nothing should be capturing the event. 1.109 + sendMouseMove(d2); 1.110 + is(d2mousemovecount, 3, "Should have got mousemove"); 1.111 + 1.112 + 1.113 + d1.addEventListener("mousemove", d1Listener2, true); 1.114 + sendMouseDown(d1); 1.115 + sendMouseMove(d1); // This should call setCapture to d2! 1.116 + d1.removeEventListener("mousemove", d1Listener2, true); 1.117 + d1.addEventListener("mousemove", d1MouseMoveListener, true); 1.118 + sendMouseMove(d1); // This should send mouse event to d2. 1.119 + is(d1mousemovecount, 1, "Shouldn't have got mousemove"); 1.120 + is(d2mousemovecount, 4, "Should have got mousemove"); 1.121 + sendMouseUp(d1); 1.122 + 1.123 + SimpleTest.finish(); 1.124 +} 1.125 + 1.126 +</script> 1.127 +</pre> 1.128 +<div class="test" id="d1"> </div><br><div class="test" id="d2"> </div> 1.129 +<pre id="l"></pre> 1.130 +</body> 1.131 +</html>