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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Bug 1646493 - test_pointerlock_focus.html</title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<script src="/tests/SimpleTest/EventUtils.js"></script>
<link rel="stylesheet" href="/tests/SimpleTest/test.css">
<style>
#target {
width: 50px;
height: 50px;
background-color: green;
}
iframe {
width: 250px;
height: 50px;
}
</style>
</head>
<body style="width: 100vw; height: 100vh; margin: 0;">
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=1646493">Mozilla Bug 1646493</a><br>
<div id="target"></div>
<input id="input"><br>
<iframe id="iframe" src="https://example.com/tests/dom/tests/mochitest/pointerlock/iframe_differentDOM.html"></iframe>
<script>
function waitForEventOnce(aTarget, aEvent) {
return new Promise(aResolve => {
aTarget.addEventListener(aEvent, aResolve, { once: true });
});
}
function unexpectedEvent(aEvent) {
ok(false, `Unexpected ${aEvent.type} event`);
}
async function requestPointerLock(aElement) {
let doc = aElement.ownerDocument;
doc.addEventListener("pointerlockerror", unexpectedEvent);
SpecialPowers.wrap(doc).notifyUserGestureActivation();
aElement.requestPointerLock();
await waitForEventOnce(doc, "pointerlockchange");
is(doc.pointerLockElement, aElement, "target pointer locked");
doc.removeEventListener("pointerlockerror", unexpectedEvent);
}
async function exitPointerLock(aDocument) {
if (aDocument.pointerLockElement) {
aDocument.exitPointerLock();
await waitForEventOnce(aDocument, "pointerlockchange");
}
is(aDocument.pointerLockElement, null, "pointer unlocked");
}
let target = document.getElementById("target");
let input = document.getElementById("input");
add_task(async function init() {
await SimpleTest.promiseFocus();
});
add_task(async function focusMovesIntoXoriginIframe() {
let iframe = document.getElementById("iframe");
input.focus();
is(document.activeElement, input, "focus input");
// Request pointer lock on parent window
await requestPointerLock(target);
// Move focus into child window with different origin
let win = iframe.contentWindow;
document.addEventListener("pointerlockchange", unexpectedEvent);
synthesizeKey("KEY_Tab");
await SpecialPowers.spawn(win, [], async () => {
if (!content.document.hasFocus()) {
await new Promise((resolve) => {
content.document.addEventListener('focus', resolve, { once: true });
});
}
});
is(document.pointerLockElement, target, "target pointer locked");
document.removeEventListener("pointerlockchange", unexpectedEvent);
// Exit pointer lock
await exitPointerLock(document);
});
add_task(async function focusMovesToAnotherTab() {
input.focus();
is(document.activeElement, input, "focus input");
// Request pointer lock on parent window
await requestPointerLock(target);
// Move focus to another tab
let promise = waitForEventOnce(document, "pointerlockchange");
let win = window.open('iframe_differentDOM.html');
await promise;
is(document.pointerLockElement, null, "pointer unlocked");
win.close();
await exitPointerLock(document);
});
</script>
</body>
</html>
|