general.any.js (4334B)
1 // META: timeout=long 2 // META: global=window,worker 3 // META: script=/common/get-host-info.sub.js 4 // META: script=/common/utils.js 5 6 // Helpers that return headers objects with a particular guard 7 function headersGuardNone(fill) { 8 if (fill) return new Headers(fill); 9 return new Headers(); 10 } 11 12 function headersGuardResponse(fill) { 13 const opts = {}; 14 if (fill) opts.headers = fill; 15 return new Response('', opts).headers; 16 } 17 18 function headersGuardRequest(fill) { 19 const opts = {}; 20 if (fill) opts.headers = fill; 21 return new Request('./', opts).headers; 22 } 23 24 function headersGuardRequestNoCors(fill) { 25 const opts = { mode: 'no-cors' }; 26 if (fill) opts.headers = fill; 27 return new Request('./', opts).headers; 28 } 29 30 const headerGuardTypes = [ 31 ['none', headersGuardNone], 32 ['response', headersGuardResponse], 33 ['request', headersGuardRequest] 34 ]; 35 36 for (const [guardType, createHeaders] of headerGuardTypes) { 37 test(() => { 38 // There are three ways to set headers. 39 // Filling, appending, and setting. Test each: 40 let headers = createHeaders({ Range: 'foo' }); 41 assert_equals(headers.get('Range'), 'foo'); 42 43 headers = createHeaders(); 44 headers.append('Range', 'foo'); 45 assert_equals(headers.get('Range'), 'foo'); 46 47 headers = createHeaders(); 48 headers.set('Range', 'foo'); 49 assert_equals(headers.get('Range'), 'foo'); 50 }, `Range header setting allowed for guard type: ${guardType}`); 51 } 52 53 test(() => { 54 let headers = headersGuardRequestNoCors({ Range: 'foo' }); 55 assert_false(headers.has('Range')); 56 57 headers = headersGuardRequestNoCors(); 58 headers.append('Range', 'foo'); 59 assert_false(headers.has('Range')); 60 61 headers = headersGuardRequestNoCors(); 62 headers.set('Range', 'foo'); 63 assert_false(headers.has('Range')); 64 }, `Privileged header not allowed for guard type: request-no-cors`); 65 66 promise_test(async () => { 67 const wavURL = new URL('resources/long-wav.py', location); 68 const stashTakeURL = new URL('resources/stash-take.py', location); 69 70 function changeToken() { 71 const stashToken = token(); 72 wavURL.searchParams.set('accept-encoding-key', stashToken); 73 stashTakeURL.searchParams.set('key', stashToken); 74 } 75 76 const rangeHeaders = [ 77 'bytes=0-10', 78 'foo=0-10', 79 'foo', 80 '' 81 ]; 82 83 for (const rangeHeader of rangeHeaders) { 84 changeToken(); 85 86 await fetch(wavURL, { 87 headers: { Range: rangeHeader } 88 }); 89 90 const response = await fetch(stashTakeURL); 91 assert_equals(await response.json(), 'identity', `Expect identity accept-encoding if range header is ${JSON.stringify(rangeHeader)}`); 92 } 93 }, `Fetch with range header will be sent with Accept-Encoding: identity`); 94 95 promise_test(async () => { 96 const wavURL = new URL(get_host_info().HTTP_REMOTE_ORIGIN + '/fetch/range/resources/long-wav.py'); 97 const stashTakeURL = new URL('resources/stash-take.py', location); 98 99 function changeToken() { 100 const stashToken = token(); 101 wavURL.searchParams.set('accept-encoding-key', stashToken); 102 stashTakeURL.searchParams.set('key', stashToken); 103 } 104 105 const rangeHeaders = [ 106 'bytes=10-9', 107 'bytes=-0', 108 'bytes=0000000000000000000000000000000000000000000000000000000000011-0000000000000000000000000000000000000000000000000000000000111', 109 ]; 110 111 for (const rangeHeader of rangeHeaders) { 112 changeToken(); 113 await fetch(wavURL, { headers: { Range : rangeHeader} }).then(() => { throw "loaded with range header " + rangeHeader }, () => { }); 114 } 115 }, `Cross Origin Fetch with non safe range header`); 116 117 promise_test(async () => { 118 const wavURL = new URL(get_host_info().HTTP_REMOTE_ORIGIN + '/fetch/range/resources/long-wav.py'); 119 const stashTakeURL = new URL('resources/stash-take.py', location); 120 121 function changeToken() { 122 const stashToken = token(); 123 wavURL.searchParams.set('accept-encoding-key', stashToken); 124 stashTakeURL.searchParams.set('key', stashToken); 125 } 126 127 const rangeHeaders = [ 128 'bytes=0-10', 129 'bytes=0-', 130 'bytes=00000000000000000000000000000000000000000000000000000000011-00000000000000000000000000000000000000000000000000000000000111', 131 ]; 132 133 for (const rangeHeader of rangeHeaders) { 134 changeToken(); 135 await fetch(wavURL, { headers: { Range: rangeHeader } }).then(() => { }, () => { throw "failed load with range header " + rangeHeader }); 136 } 137 }, `Cross Origin Fetch with safe range header`);