summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/resize-observer/resources/iframe.html
blob: 5c801e63682fd6f9e0971c2a61d16347dc6e5d2d (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
<!doctype html>
<head>
  <script src="./resizeTestHelper.js"></script>
</head>
<p>iframe test</p>
<div id="itarget1" style="width:100px;height:100px;">t1</div>
<script>
'use strict';
let t1 = document.querySelector('#itarget1');
function test0() {
  let timeoutId = window.setTimeout( () => {
    window.parent.postMessage('fail', '*');
  }, ResizeTestHelper.TIMEOUT);
  let ro = new ResizeObserver(function(entries) {
    window.clearTimeout(timeoutId);
    window.parent.postMessage('success', '*');
  });
  ro.observe(t1);
}
let testStarted = false;
window.addEventListener('message', function(ev) {
    switch(ev.data) {
        case 'startTest':
          testStarted = true;
          test0();
        break;
    }
});
// How does parent know we've loaded problem is solved by
// broadcasting readyToTest message repeatedly until test starts.
function broadcastReady() {
  if (!testStarted) {
    window.parent.postMessage('readyToTest', '*');
    window.requestAnimationFrame(broadcastReady);
  }
}
window.onload = broadcastReady;
</script>