File: resource-timing-cross-origin.https.html

package info (click to toggle)
firefox-esr 91.13.0esr-1~deb11u1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 3,375,652 kB
  • sloc: cpp: 5,762,054; javascript: 5,481,714; ansic: 3,121,191; python: 851,492; asm: 331,172; xml: 178,949; java: 155,554; sh: 63,704; makefile: 20,127; perl: 12,825; yacc: 4,583; cs: 3,846; objc: 3,026; lex: 1,720; exp: 762; pascal: 635; php: 436; lisp: 260; awk: 231; ruby: 103; sed: 53; sql: 46; csh: 45
file content (52 lines) | stat: -rw-r--r-- 2,502 bytes parent folder | download | duplicates (10)
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
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8" />
<title>This test validates Resource Timing for cross origin content fetched by Service Worker from an originally same-origin URL.</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script src="resources/test-helpers.sub.js"></script>
</head>

<body>
<script>
async_test(function(t) {
    const worker_url = 'resources/worker-fetching-cross-origin.js';
    const scope = 'resources/iframe-with-image.html';
    let registration;
    service_worker_unregister_and_register(t, worker_url, scope)
    .then(function(r) {
        registration = r;
        return wait_for_state(t, r.installing, 'activated');
    })
    .then(function() {
        return with_iframe(scope);
    })
    .then(function(frame) {
        const frame_performance = frame.contentWindow.performance;
        // Check that there is one entry for which the timing allow check algorithm failed.
        const entries = frame_performance.getEntriesByType('resource');
        assert_equals(entries.length, 1);
        const entry = entries[0];
        assert_equals(entry.redirectStart, 0, 'redirectStart should be 0 in cross-origin request.');
        assert_equals(entry.redirectEnd, 0, 'redirectEnd should be 0 in cross-origin request.');
        assert_equals(entry.domainLookupStart, 0, 'domainLookupStart should be 0 in cross-origin request.');
        assert_equals(entry.domainLookupEnd, 0, 'domainLookupEnd should be 0 in cross-origin request.');
        assert_equals(entry.connectStart, 0, 'connectStart should be 0 in cross-origin request.');
        assert_equals(entry.connectEnd, 0, 'connectEnd should be 0 in cross-origin request.');
        assert_equals(entry.requestStart, 0, 'requestStart should be 0 in cross-origin request.');
        assert_equals(entry.responseStart, 0, 'responseStart should be 0 in cross-origin request.');
        assert_equals(entry.secureConnectionStart, 0, 'secureConnectionStart should be 0 in cross-origin request.');
        assert_equals(entry.decodedBodySize, 0, 'decodedBodySize should be 0 in cross-origin request.');
        frame.remove();
        return registration.unregister();
      })
    .then(function() {
        t.done();
      })
    .catch(unreached_rejection(t));
}, 'Test that timing allow check fails when service worker changes origin from same to cross origin.');
</script>
</body>
</html>