summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/dom/events/passive-by-default.html
blob: 02029f4dacf81180c846b27f0f2de4b0e8f5cc05 (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
<!DOCTYPE html>
<title>Default passive event listeners on window, document, document element, body</title>
<link rel="help" href="https://dom.spec.whatwg.org/#default-passive-value">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<body>
  <div id="div"></div>
<script>
  function isListenerPassive(eventName, eventTarget, passive, expectPassive) {
    test(() => {
      let defaultPrevented = null;
      let handler = event => {
        event.preventDefault();
        defaultPrevented = event.defaultPrevented;
        eventTarget.removeEventListener(eventName, handler);
      };
      if (passive === 'omitted') {
        eventTarget.addEventListener(eventName, handler);
      } else {
        eventTarget.addEventListener(eventName, handler, {passive});
      }
      let dispatchEventReturnValue = eventTarget.dispatchEvent(new Event(eventName, {cancelable: true}));
      assert_equals(defaultPrevented, !expectPassive, 'defaultPrevented');
      assert_equals(dispatchEventReturnValue, expectPassive, 'dispatchEvent() return value');
    }, `${eventName} listener is ${expectPassive ? '' : 'non-'}passive ${passive === 'omitted' ? 'by default' : `with {passive:${passive}}`} for ${eventTarget.constructor.name}`);
  }

  const eventNames = {
    touchstart: true,
    touchmove: true,
    wheel: true,
    mousewheel: true,
    touchend: false
  };
  const passiveEventTargets = [window, document, document.documentElement, document.body];
  const div = document.getElementById('div');

  for (const eventName in eventNames) {
    for (const eventTarget of passiveEventTargets) {
      isListenerPassive(eventName, eventTarget, 'omitted', eventNames[eventName]);
      isListenerPassive(eventName, eventTarget, undefined, eventNames[eventName]);
      isListenerPassive(eventName, eventTarget, false, false);
      isListenerPassive(eventName, eventTarget, true, true);
    }
    isListenerPassive(eventName, div, 'omitted', false);
    isListenerPassive(eventName, div, undefined, false);
    isListenerPassive(eventName, div, false, false);
    isListenerPassive(eventName, div, true, true);
  }
</script>