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

package info (click to toggle)
firefox-esr 68.10.0esr-1~deb9u1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 3,143,932 kB
  • sloc: cpp: 5,227,879; javascript: 4,315,531; ansic: 2,467,042; python: 794,975; java: 349,993; asm: 232,034; xml: 228,320; sh: 82,008; lisp: 41,202; makefile: 22,347; perl: 15,555; objc: 5,277; cs: 4,725; yacc: 1,778; ada: 1,681; pascal: 1,673; lex: 1,417; exp: 527; php: 436; ruby: 225; awk: 162; sed: 53; csh: 44
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>