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
56
57
58
59
60
61
62
|
// META: global=window,worker
// META: title=HTTP Cache - Content
// META: timeout=long
// META: script=/common/utils.js
// META: script=http-cache.js
// This is a tentative test.
// Firefox behavior is used as expectations.
//
// whatwg/fetch issue:
// https://github.com/whatwg/fetch/issues/1253
//
// Chrome design doc:
// https://docs.google.com/document/d/1lvbiy4n-GM5I56Ncw304sgvY5Td32R6KHitjRXvkZ6U/edit#
const request_cacheable = {
request_headers: [],
response_headers: [
['Cache-Control', 'max-age=3600'],
],
// TODO(arthursonzogni): The behavior is tested only for same-origin requests.
// It must behave similarly for cross-site and cross-origin requests. The
// problems is the http-cache.js infrastructure returns the
// "Server-Request-Count" as HTTP response headers, which aren't readable for
// CORS requests.
base_url: location.href.replace(/\/[^\/]*$/, '/'),
};
const request_credentialled = { ...request_cacheable, credentials: 'include', };
const request_anonymous = { ...request_cacheable, credentials: 'omit', };
const responseIndex = count => {
return {
expected_response_headers: [
['Server-Request-Count', count.toString()],
],
}
};
var tests = [
{
name: 'same-origin: 2xAnonymous, 2xCredentialled, 1xAnonymous',
requests: [
{ ...request_anonymous , ...responseIndex(1)} ,
{ ...request_anonymous , ...responseIndex(1)} ,
{ ...request_credentialled , ...responseIndex(2)} ,
{ ...request_credentialled , ...responseIndex(2)} ,
{ ...request_anonymous , ...responseIndex(1)} ,
]
},
{
name: 'same-origin: 2xCredentialled, 2xAnonymous, 1xCredentialled',
requests: [
{ ...request_credentialled , ...responseIndex(1)} ,
{ ...request_credentialled , ...responseIndex(1)} ,
{ ...request_anonymous , ...responseIndex(2)} ,
{ ...request_anonymous , ...responseIndex(2)} ,
{ ...request_credentialled , ...responseIndex(1)} ,
]
},
];
run_tests(tests);
|