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
|
// META: script=resources/utils.js
// META: script=/common/utils.js
const onload = new Promise(r => window.addEventListener('load', r));
// It's weird that browsers do this, but it should continue to work.
promise_test(async t => {
await loadScript('resources/partial-script.py?pretend-offset=90000');
assert_true(self.scriptExecuted);
}, `Script executed from partial response`);
promise_test(async () => {
const wavURL = new URL('resources/long-wav.py', location);
const stashTakeURL = new URL('resources/stash-take.py', location);
const stashToken = token();
wavURL.searchParams.set('accept-encoding-key', stashToken);
stashTakeURL.searchParams.set('key', stashToken);
// The testing framework waits for window onload. If the audio element
// is appended before onload, it extends it, and the test times out.
await onload;
const audio = appendAudio(document, wavURL);
await new Promise(r => audio.addEventListener('progress', r));
audio.remove();
const response = await fetch(stashTakeURL);
assert_equals(await response.json(), 'identity', `Expect identity accept-encoding on media request`);
}, `Fetch with range header will be sent with Accept-Encoding: identity`);
|