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
|
<!DOCTYPE html>
<meta charset="utf-8">
<title>Test for always-enabling lines deltaMode</title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<script src="/tests/SimpleTest/EventUtils.js"></script>
<link rel="stylesheet" href="/tests/SimpleTest/test.css"/>
<p id="display"></p>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1684001">Mozilla Bug 1684001</a>
<div id="overflow" style="height: 300vh"></div>
<pre id="test"></pre>
<script>
SimpleTest.waitForExplicitFinish();
const HACK_PREF = "dom.event.wheel-deltaMode-lines.always-enabled";
(async function() {
await SimpleTest.promiseFocus(window);
await SpecialPowers.pushPrefEnv({
set: [
[HACK_PREF, document.domain],
["test.events.async.enabled", true],
],
});
// FYI: Cannot use scrollingElement because it's center may be outside of the viewport.
await promiseElementReadyForUserInput(document.querySelector("a[href]"));
await SpecialPowers.pushPrefEnv({
clear: [
["test.events.async.enabled"],
],
});
document.addEventListener("wheel", e => {
e.deltaY; /* access the delta unchecked */
is(e.deltaMode, WheelEvent.DOM_DELTA_LINE, "Accessing wheel event data should return lines even if unchecked, if the pref is enabled for that domain");
SimpleTest.finish();
}, { once: true });
synthesizeWheel(document.scrollingElement, 10, 10, { deltaY: 3.0, deltaMode: WheelEvent.DOM_DELTA_LINE });
}());
</script>
|