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
|
<!DOCTYPE>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Checking zoomToFocusedInput scrolls that focused element is into iframe</title>
<script type="application/javascript" src="apz_test_utils.js"></script>
<script type="application/javascript" src="apz_test_native_event_utils.js"></script>
<script src="/tests/SimpleTest/paint_listener.js"></script>
</head>
<body>
<div style="height: 8000px;">ABC</div>
<iframe style="height: 30em;"></iframe>
</div>
<!-- Leave additional room below the element so it can be scrolled to the center -->
<div style="height: 1000px;">ABC</div>
<script type="application/javascript">
async function test() {
let isCrossOrigin = (location.search == "?cross-origin");
let iframeURL =
SimpleTest.getTestFileURL("helper_iframe_textarea.html")
if (isCrossOrigin) {
iframeURL.replace(window.location.origin, "https://example.com/");
}
let iframe = document.querySelector("iframe");
const iframeLoadPromise = promiseOneEvent(iframe, "load", null);
iframe.src = iframeURL;
await iframeLoadPromise;
await SpecialPowers.spawn(iframe, [], async () => {
await content.wrappedJSObject.waitUntilApzStable();
});
iframe.focus();
await SpecialPowers.spawn(iframe, [], async () => {
let textarea = content.document.querySelector("textarea");
for (let i = 0; i < 20; i++) {
textarea.value += "foo\n";
}
textarea.focus();
});
await SpecialPowers.spawn(iframe, [], async () => {
await content.wrappedJSObject.waitToClearOutAnyPotentialScrolls(content.window);
});
await SpecialPowers.spawn(iframe, [], async () => {
let textarea = content.document.querySelector("textarea");
textarea.setSelectionRange(0, 0);
});
window.scrollTo(0, 0);
await SpecialPowers.spawn(iframe, [], async () => {
await content.wrappedJSObject.waitToClearOutAnyPotentialScrolls(content.window);
});
is(0, window.scrollY, "scroll position is reset");
let transformEndPromise = promiseTransformEnd();
await SpecialPowers.spawn(iframe, [], async () => {
SpecialPowers.DOMWindowUtils.zoomToFocusedInput();
});
await promiseApzFlushedRepaints();
ok(window.scrollY > 0, "scroll position isn't top");
let iframeWindowScrollY = await SpecialPowers.spawn(iframe, [], () => {
return content.window.scrollY;
});
ok(iframeWindowScrollY > 0, "scroll position into iframe isn't top");
let prevPosY = window.scrollY;
await transformEndPromise;
await promiseApzFlushedRepaints();
window.scrollTo(0, 0);
await SpecialPowers.spawn(iframe, [], async () => {
await content.wrappedJSObject.waitToClearOutAnyPotentialScrolls(content.window);
});
is(0, window.scrollY, "scroll position is reset");
SpecialPowers.spawn(iframe, [], async () => {
let textarea = content.document.querySelector("textarea");
textarea.setSelectionRange(textarea.value.length, textarea.value.length);
});
transformEndPromise = promiseTransformEnd();
await SpecialPowers.spawn(iframe, [], async () => {
SpecialPowers.DOMWindowUtils.zoomToFocusedInput();
});
await transformEndPromise;
await promiseApzFlushedRepaints();
ok(window.scrollY > 0, "scroll position isn't top");
iframeWindowScrollY = await SpecialPowers.spawn(iframe, [], () => {
return content.window.scrollY;
});
ok(iframeWindowScrollY > 0, "scroll position into iframe isn't top");
ok(prevPosY < window.scrollY,
"scroll position is different from first line of textarea");
}
waitUntilApzStable().then(test).then(subtestDone, subtestFailed);
</script>
</body>
</html>
|