summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/uievents/mouse/attributes.html
blob: bbc388445c052293091739db39719d5e3a27e1a5 (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
52
53
54
55
56
57
58
59
60
61
<!DOCTYPE HTML>
<title>MouseEvent attributes</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-actions.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
<script src="resources/utils.js"></script>

<span id="left">Left</span> <span id="right">Right</span>

<script>
  'use strict';

  const event_list = ["mouseover", "mouseenter", "mousemove",
                      "mousedown", "mouseup", "mouseout", "mouseleave"];

  promise_test(async () => {
      let left = document.getElementById("left");
      let right = document.getElementById("right");

      let event_promises = [];
      event_list.forEach(ename => event_promises.push(getEvent(ename, right)));

      let actions = new test_driver.Actions().addPointer("TestPointer", "mouse")
          .pointerMove(0, 0, {origin: left})
          .pointerDown()
          .pointerUp()
          .pointerMove(0, 0, {origin: right})
          .pointerDown()
          .pointerUp()
          .pointerMove(0, 0, {origin: left})
          .pointerDown()
          .pointerUp()
      await actions.send();

      for (let i = 0; i < event_promises.length; i++) {
          let e = await event_promises[i];

          assert_equals(e.constructor, window.MouseEvent,
                        e.type + " should use a MouseEvent constructor");
          assert_true(e instanceof MouseEvent,
                      e.type + " should be a MouseEvent");

          assert_true(e.isTrusted,
                      e.type + ".isTrusted attribute");

          assert_equals(e.composed,
                        e.type != 'mouseenter' && e.type != 'mouseleave',
                        e.type + ".composed attribute");

          assert_equals(e.bubbles,
                        e.type != 'mouseenter' && e.type != 'mouseleave',
                        e.type + ".bubbles attribute");

          assert_equals(e.cancelable,
                        e.type != 'mouseenter' && e.type != 'mouseleave',
                        e.type + ".cancelable attribute");
      }
  }, "MouseEvent attributes");
</script>