summaryrefslogtreecommitdiffstats
path: root/gfx/layers/apz/test/mochitest/helper_zoomToFocusedInput_iframe.html
blob: d916c35efb645b6fedec75da874b4ccf02fc925f (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
62
63
64
65
66
67
68
<!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;" src="helper_iframe_textarea.html"></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 utils = SpecialPowers.getDOMWindowUtils(window);

  let iframe = document.querySelector("iframe");
  let textarea = iframe.contentDocument.querySelector("textarea");
  for (let i = 0; i < 20; i++) {
    textarea.value += "foo\n";
  }

  let win = iframe.contentWindow;

  iframe.focus();
  textarea.focus();

  await waitToClearOutAnyPotentialScrolls(win);

  textarea.setSelectionRange(0, 0);
  window.scrollTo(0, 0);
  await waitToClearOutAnyPotentialScrolls(win);
  is(0, window.scrollY, "scroll position is reset");

  let transformEndPromise = promiseTransformEnd();
  utils.zoomToFocusedInput();
  await promiseApzFlushedRepaints();

  ok(window.scrollY > 0, "scroll position isn't top");
  ok(iframe.contentWindow.scrollY > 0, "scroll position into iframe isn't top");
  let prevPosY = window.scrollY;

  await transformEndPromise;
  await promiseApzFlushedRepaints();

  window.scrollTo(0, 0);
  await waitToClearOutAnyPotentialScrolls(win);
  is(0, window.scrollY, "scroll position is reset");

  textarea.setSelectionRange(textarea.value.length, textarea.value.length);
  transformEndPromise = promiseTransformEnd();
  utils.zoomToFocusedInput();
  await transformEndPromise;
  await promiseApzFlushedRepaints();

  ok(window.scrollY > 0, "scroll position isn't top");
  ok(iframe.contentWindow.scrollY > 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>