summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/intersection-observer/same-origin-grand-child-iframe.sub.html
blob: a311a8732ab15c3d61ed9ea51a37b5b4079f2e09 (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
<!DOCTYPE html>
<meta charset=utf-8>
<meta name="viewport" content="width=device-width,initial-scale=1">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script src="./resources/intersection-observer-test-utils.js"></script>
<iframe scrolling="no" frameborder="0" id="iframe"></iframe>
<script>
promise_test(async t => {
  iframe.src =
    get_host_info().HTTP_NOTSAMESITE_ORIGIN + "/intersection-observer/resources/cross-origin-child-iframe.sub.html";

  const { rootBounds, intersectionRect } = await new Promise(resolve => {
    window.addEventListener("message", event => resolve(event.data));
  }, { once: true } );

  // 300px = iframe viewport width
  // 8px = default body margin
  // (intersectionRect is in the coordinate space of the target iframe)
  assert_equals(intersectionRect.top, 8);
  assert_equals(intersectionRect.left, 200);
  assert_equals(intersectionRect.right, 300 - 8);
  assert_equals(intersectionRect.width, 100 - 8);
  assert_equals(intersectionRect.height, 100);

  assert_equals(rootBounds.left, 0);
  assert_equals(rootBounds.top, 0);
  assert_equals(rootBounds.right, document.documentElement.clientWidth);
  assert_equals(rootBounds.bottom, document.documentElement.clientHeight);
}, "rootBounds in a same-origin iframe in the case where there is a cross-origin "
+  "iframe in between the top document and the same origin iframe");
</script>