summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/longtask-timing/resources/subframe-observing-longtask.html
blob: 125ff1e4cb5391eeb8abd7d3ac69c71f912baada (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
<!DOCTYPE HTML>
<meta charset=utf-8>
<meta name="viewport" content="width=device-width">
<title>Child Iframe</title>
<h1>Child Iframe observing long tasks</h1>

<script>
    const observer = new PerformanceObserver(function(entryList) {
      for (i = 0; i < entryList.getEntries().length; i++) {
        const longtask = entryList.getEntries()[i];
         // Ignore long task generated within here, as part of making this iframe.
         // Ignore multiple-contexts and unknown because they cause longtask-in-parentiframe test to be flaky.
        if (longtask.name == 'self' ||
            longtask.name == 'multiple-contexts' || longtask.name == 'unknown')
          return;
        // TODO(panicker): include containerType.
        const attribution = longtask.attribution[0];
        const entryContents = {
          'entryType': longtask.entryType,
          'frame-attribution': longtask.name,
          'task-attribution': attribution.name,
          'containerType': attribution.containerType,
          'containerId': attribution.containerId,
          'containerName': attribution.containerName,
          'containerSrc': attribution.containerSrc
        };
        top.postMessage(entryContents, '*');
      }
    });
    observer.observe({entryTypes: ['longtask']});
</script>