layout/base/tests/test_bug582771.html

changeset 0
6474c204b198
     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">&nbsp;</div><br><div class="test" id="d2">&nbsp;</div>
   1.129 +<pre id="l"></pre>
   1.130 +</body>
   1.131 +</html>

mercurial