File: resource-timing-bodySize.https.html

package info (click to toggle)
thunderbird 1%3A128.14.0esr-1~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 4,334,824 kB
  • sloc: cpp: 7,391,917; javascript: 5,617,271; ansic: 3,833,216; python: 1,230,742; xml: 619,690; asm: 456,022; java: 179,892; sh: 118,796; makefile: 21,908; perl: 14,825; objc: 12,399; yacc: 4,583; pascal: 2,973; lex: 1,720; ruby: 1,190; exp: 762; sql: 674; awk: 580; php: 436; lisp: 430; sed: 70; csh: 10
file content (55 lines) | stat: -rw-r--r-- 2,508 bytes parent folder | download | duplicates (19)
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
53
54
55
<!DOCTYPE html>
<meta charset="utf-8">
<meta name="timeout" content="long">
<script src="/common/utils.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="resources/test-helpers.sub.js"></script>
<script>
const {REMOTE_ORIGIN} = get_host_info();

/*
  This test does the following:
  - Loads a service worker
  - Loads an iframe in the service worker's scope
  - The service worker tries to fetch a resource which is either:
    - constructed inside the service worker
    - fetched from a different URL ny the service worker
    - Streamed from a differend URL by the service worker
    - Passes through
  - By default the RT entry should have encoded/decoded body size. except for
    the case where the response is an opaque pass-through.
*/
function test_scenario({tao, mode, name}) {
    promise_test(async (t) => {
        const uid = token();
        const worker_url = `resources/fetch-response.js?uid=${uid}`;
        const scope = `resources/fetch-response.html?uid=${uid}`;
        const iframe = document.createElement('iframe');
        const path = name === "passthrough" ? `element-timing/resources/TAOImage.py?origin=*&tao=${
            tao === "pass" ? "wildcard" : "none"})}` : name;

        iframe.src = `${scope}&path=${encodeURIComponent(
            `${mode === "same-origin" ? "" : REMOTE_ORIGIN}/${path}`)}&mode=${mode}`;
        const registration = await service_worker_unregister_and_register(t, worker_url, scope);
        t.add_cleanup(() => registration.unregister());
        t.add_cleanup(() => iframe.remove());
        await wait_for_state(t, registration.installing, 'activated');
        const waitForMessage = new Promise(resolve =>
          window.addEventListener('message', ({data}) => resolve(data)));
        document.body.appendChild(iframe);
        const {buffer, entry} = await waitForMessage;
        const expectPass = name !== "passthrough" || mode !== "no-cors";
        assert_equals(buffer.byteLength, expectPass ? entry.decodedBodySize : 0);
        assert_equals(buffer.byteLength, expectPass ? entry.encodedBodySize : 0);
    }, `Response body size: ${name}, ${mode}, TAO ${tao}`);
}
for (const mode of ["cors", "no-cors", "same-origin"]) {
  for (const tao of ["pass", "fail"])
    for (const name of ['constructed', 'forward', 'stream', 'passthrough']) {
      test_scenario({tao, mode, name});
    }
}

</script>