summaryrefslogtreecommitdiffstats
path: root/dom/events/test/pointerevents/test_bug1285128.html
blob: 534e26504762165f5cd7d035e7a5e0bce10d00dc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=1285128
-->
<head>
  <meta charset="utf-8">
  <title>Test for Bug 1285128</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <script src="/tests/SimpleTest/EventUtils.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1285128">Mozilla Bug 1285128</a>
<p id="display"></p>
<div id="target0" style="width: 50px; height: 50px; background: green"></div>
<div id="target1" style="width: 50px; height: 50px; background: red"></div>
<script type="text/javascript">

/** Test for Bug 1285128 **/
SimpleTest.waitForExplicitFinish();

function runTests() {
  let target0 = window.document.getElementById("target0");
  let pointerEventsList = ["pointerover", "pointerenter", "pointerdown",
                           "pointerup", "pointerleave", "pointerout"];
  let receivedPointerEvents = false;
  pointerEventsList.forEach((elem, index, arr) => {
    target0.addEventListener(elem, (event) => {
      ok(false, "receiving event " + event.type);
      receivedPointerEvents = true;
    });
  });

  target1.addEventListener("mouseup", () => {
    ok(!receivedPointerEvents, "synthesized mousemove should not trigger any pointer events");
    SimpleTest.finish();
  });

  synthesizeMouseAtCenter(target0, { type: "mousemove",
                                     inputSource: MouseEvent.MOZ_SOURCE_MOUSE,
                                     isWidgetEventSynthesized: true });
  synthesizeMouseAtCenter(target1, { type: "mousedown" });
  synthesizeMouseAtCenter(target1, { type: "mouseup" });
}

SimpleTest.waitForFocus(runTests);

</script>
</body>
</html>