summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/hr-time/navigation-start-post-before-unload.html
blob: 88ee5db77eb0e60f97d5f823f5d62708c34b366c (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>
<html>
<head>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
</head>
<body>
<script>
    function busyWait(millis) {
        const start = performance.now();
        while (performance.now() < start + millis) {}
    }
    promise_test(async t => {
        const delay = 3000;
        const iframe = document.createElement('iframe');
        iframe.src = './resources/now_frame.html';
        document.body.appendChild(iframe);
        await new Promise(resolve => iframe.addEventListener('load', resolve));
        iframe.contentWindow.addEventListener('beforeunload', () => {
            busyWait(delay);
        });
        iframe.src = './resources/post.html';
        await new Promise(resolve => this.addEventListener('message', ({data}) => {
            if (data === 'done')
                resolve();
        }));

        const entry = iframe.contentWindow.performance.getEntriesByType('navigation')[0];
        assert_less_than(entry.fetchStart, delay);
    }, 'timeOrigin should be set after beforeunload');
</script>
</body>
</html>