Index: LayoutTests/http/tests/cachestorage/script-tests/cache-match.js |
diff --git a/LayoutTests/http/tests/cachestorage/script-tests/cache-match.js b/LayoutTests/http/tests/cachestorage/script-tests/cache-match.js |
index b5e5a8c04630e0085d7ea06829a3567b4e5159bb..4c9ce2d6ef2c5076c20d8dd398c3ccea7aebd79d 100644 |
--- a/LayoutTests/http/tests/cachestorage/script-tests/cache-match.js |
+++ b/LayoutTests/http/tests/cachestorage/script-tests/cache-match.js |
@@ -4,136 +4,6 @@ if (self.importScripts) { |
importScripts('../resources/test-helpers.js'); |
} |
-// A set of Request/Response pairs to be used with prepopulated_cache_test(). |
-var simple_entries = [ |
- { |
- name: 'a', |
- request: new Request('http://example.com/a'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'b', |
- request: new Request('http://example.com/b'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'a_with_query', |
- request: new Request('http://example.com/a?q=r'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'A', |
- request: new Request('http://example.com/A'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'a_https', |
- request: new Request('https://example.com/a'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'a_org', |
- request: new Request('http://example.org/a'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'cat', |
- request: new Request('http://example.com/cat'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'catmandu', |
- request: new Request('http://example.com/catmandu'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'cat_num_lives', |
- request: new Request('http://example.com/cat?lives=9'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'cat_in_the_hat', |
- request: new Request('http://example.com/cat/in/the/hat'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'secret_cat', |
- request: new Request('http://tom:jerry@example.com/cat'), |
- response: new Response('') |
- }, |
- |
- { |
- name: 'top_secret_cat', |
- request: new Request('http://tom:j3rry@example.com/cat'), |
- response: new Response('') |
- }, |
- { |
- name: 'non_2xx_response', |
- request: new Request('http://example.com/non2xx'), |
- response: new Response('', {status: 404, statusText: 'nope'}) |
- }, |
- |
- { |
- name: 'error_response', |
- request: new Request('http://example.com/error'), |
- response: Response.error() |
- }, |
-]; |
- |
-// A set of Request/Response pairs to be used with prepopulated_cache_test(). |
-// These contain a mix of test cases that use Vary headers. |
-var vary_entries = [ |
- { |
- name: 'vary_cookie_is_cookie', |
- request: new Request('http://example.com/c', |
- {headers: {'Cookies': 'is-for-cookie'}}), |
- response: new Response('', |
- {headers: {'Vary': 'Cookies'}}) |
- }, |
- |
- { |
- name: 'vary_cookie_is_good', |
- request: new Request('http://example.com/c', |
- {headers: {'Cookies': 'is-good-enough-for-me'}}), |
- response: new Response('', |
- {headers: {'Vary': 'Cookies'}}) |
- }, |
- |
- { |
- name: 'vary_cookie_absent', |
- request: new Request('http://example.com/c'), |
- response: new Response('', |
- {headers: {'Vary': 'Cookies'}}) |
- }, |
- |
- { |
- name: 'vary_wildcard', |
- request: new Request('http://example.com/c', |
- {headers: {'Cookies': 'x', 'X-Key': '1'}}), |
- response: new Response('', |
- {headers: {'Vary': '*'}}) |
- } |
-]; |
- |
-prepopulated_cache_test(simple_entries, function(cache, entries) { |
- return cache.matchAll('not-present-in-the-cache') |
- .then(function(result) { |
- assert_array_equivalent( |
- result, [], |
- 'Cache.matchAll should resolve with an empty array on failure.'); |
- }); |
- }, 'Cache.matchAll with no matching entries'); |
- |
prepopulated_cache_test(simple_entries, function(cache, entries) { |
return cache.match('not-present-in-the-cache') |
.then(function(result) { |
@@ -143,14 +13,6 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
}, 'Cache.match with no matching entries'); |
prepopulated_cache_test(simple_entries, function(cache, entries) { |
- return cache.matchAll(entries.a.request.url) |
- .then(function(result) { |
- assert_array_equivalent(result, [entries.a.response], |
- 'Cache.matchAll should match by URL.'); |
- }); |
- }, 'Cache.matchAll with URL'); |
- |
-prepopulated_cache_test(simple_entries, function(cache, entries) { |
return cache.match(entries.a.request.url) |
.then(function(result) { |
assert_object_equals_fixed(result, entries.a.response, |
@@ -159,14 +21,6 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
}, 'Cache.match with URL'); |
prepopulated_cache_test(simple_entries, function(cache, entries) { |
- return cache.matchAll(entries.a.request) |
- .then(function(result) { |
- assert_array_equivalent(result, [entries.a.response], |
- 'Cache.matchAll should match by Request.'); |
- }); |
- }, 'Cache.matchAll with Request'); |
- |
-prepopulated_cache_test(simple_entries, function(cache, entries) { |
return cache.match(entries.a.request) |
.then(function(result) { |
assert_object_equals_fixed(result, entries.a.response, |
@@ -175,14 +29,6 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
}, 'Cache.match with Request'); |
prepopulated_cache_test(simple_entries, function(cache, entries) { |
- return cache.matchAll(new Request(entries.a.request.url)) |
- .then(function(result) { |
- assert_array_equivalent(result, [entries.a.response], |
- 'Cache.matchAll should match by Request.'); |
- }); |
- }, 'Cache.matchAll with new Request'); |
- |
-prepopulated_cache_test(simple_entries, function(cache, entries) { |
return cache.match(new Request(entries.a.request.url)) |
.then(function(result) { |
assert_object_equals_fixed(result, entries.a.response, |
@@ -191,23 +37,6 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
}, 'Cache.match with new Request'); |
prepopulated_cache_test(simple_entries, function(cache, entries) { |
- return cache.matchAll(entries.a.request, |
- {ignoreSearch: true}) |
- .then(function(result) { |
- assert_array_equivalent( |
- result, |
- [ |
- entries.a.response, |
- entries.a_with_query.response |
- ], |
- 'Cache.matchAll with ignoreSearch should ignore the ' + |
- 'search parameters of cached request.'); |
- }); |
- }, |
- 'Cache.matchAll with ignoreSearch option (request with no search ' + |
- 'parameters)'); |
- |
-prepopulated_cache_test(simple_entries, function(cache, entries) { |
return cache.match(entries.a.request, |
{ignoreSearch: true}) |
.then(function(result) { |
@@ -225,22 +54,6 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
'parameters)'); |
prepopulated_cache_test(simple_entries, function(cache, entries) { |
- return cache.matchAll(entries.a_with_query.request, |
- {ignoreSearch: true}) |
- .then(function(result) { |
- assert_array_equivalent( |
- result, |
- [ |
- entries.a.response, |
- entries.a_with_query.response |
- ], |
- 'Cache.matchAll with ignoreSearch should ignore the ' + |
- 'search parameters of request.'); |
- }); |
- }, |
- 'Cache.matchAll with ignoreSearch option (request with search parameter)'); |
- |
-prepopulated_cache_test(simple_entries, function(cache, entries) { |
return cache.match(entries.a_with_query.request, |
{ignoreSearch: true}) |
.then(function(result) { |
@@ -257,18 +70,6 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
'Cache.match with ignoreSearch option (request with search parameter)'); |
prepopulated_cache_test(simple_entries, function(cache, entries) { |
- return cache.matchAll(entries.cat.request.url + '#mouse') |
- .then(function(result) { |
- assert_array_equivalent( |
- result, |
- [ |
- entries.cat.response, |
- ], |
- 'Cache.matchAll should ignore URL fragment.'); |
- }); |
- }, 'Cache.matchAll with URL containing fragment'); |
- |
-prepopulated_cache_test(simple_entries, function(cache, entries) { |
return cache.match(entries.cat.request.url + '#mouse') |
.then(function(result) { |
assert_object_equals_fixed(result, entries.cat.response, |
@@ -277,16 +78,6 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
}, 'Cache.match with URL containing fragment'); |
prepopulated_cache_test(simple_entries, function(cache, entries) { |
- return cache.matchAll('http') |
- .then(function(result) { |
- assert_array_equivalent( |
- result, [], |
- 'Cache.matchAll should treat query as a URL and not ' + |
- 'just a string fragment.'); |
- }); |
- }, 'Cache.matchAll with string fragment "http" as query'); |
- |
-prepopulated_cache_test(simple_entries, function(cache, entries) { |
return cache.match('http') |
.then(function(result) { |
assert_equals( |
@@ -297,15 +88,6 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
}, 'Cache.match with string fragment "http" as query'); |
prepopulated_cache_test(simple_entries, function(cache, entries) { |
- return cache.matchAll(entries.secret_cat.request.url) |
- .then(function(result) { |
- assert_array_equivalent( |
- result, [entries.secret_cat.response], |
- 'Cache.matchAll should not ignore embedded credentials'); |
- }); |
- }, 'Cache.matchAll with URL containing credentials'); |
- |
-prepopulated_cache_test(simple_entries, function(cache, entries) { |
return cache.match(entries.secret_cat.request.url) |
.then(function(result) { |
assert_object_equals_fixed( |
@@ -315,50 +97,6 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
}, 'Cache.match with URL containing credentials'); |
prepopulated_cache_test(vary_entries, function(cache, entries) { |
- return cache.matchAll('http://example.com/c') |
- .then(function(result) { |
- assert_array_equivalent( |
- result, |
- [ |
- entries.vary_wildcard.response, |
- entries.vary_cookie_absent.response |
- ], |
- 'Cache.matchAll should exclude matches if a vary header is ' + |
- 'missing in the query request, but is present in the cached ' + |
- 'request.'); |
- }) |
- |
- .then(function() { |
- return cache.matchAll( |
- new Request('http://example.com/c', |
- {headers: {'Cookies': 'none-of-the-above'}})); |
- }) |
- .then(function(result) { |
- assert_array_equivalent( |
- result, |
- [ |
- entries.vary_wildcard.response |
- ], |
- 'Cache.matchAll should exclude matches if a vary header is ' + |
- 'missing in the cached request, but is present in the query ' + |
- 'request.'); |
- }) |
- |
- .then(function() { |
- return cache.matchAll( |
- new Request('http://example.com/c', |
- {headers: {'Cookies': 'is-for-cookie'}})); |
- }) |
- .then(function(result) { |
- assert_array_equivalent( |
- result, |
- [entries.vary_cookie_is_cookie.response], |
- 'Cache.matchAll should match the entire header if a vary header ' + |
- 'is present in both the query and cached requests.'); |
- }); |
- }, 'Cache.matchAll with responses containing "Vary" header'); |
- |
-prepopulated_cache_test(vary_entries, function(cache, entries) { |
return cache.match('http://example.com/c') |
.then(function(result) { |
assert_object_in_array( |
@@ -371,22 +109,6 @@ prepopulated_cache_test(vary_entries, function(cache, entries) { |
}); |
}, 'Cache.match with responses containing "Vary" header'); |
-prepopulated_cache_test(vary_entries, function(cache, entries) { |
- return cache.matchAll('http://example.com/c', |
- {ignoreVary: true}) |
- .then(function(result) { |
- assert_array_equivalent( |
- result, |
- [ |
- entries.vary_cookie_is_cookie.response, |
- entries.vary_cookie_is_good.response, |
- entries.vary_cookie_absent.response, |
- entries.vary_wildcard.response |
- ], |
- 'Cache.matchAll should honor "ignoreVary" parameter.'); |
- }); |
- }, 'Cache.matchAll with "ignoreVary" parameter'); |
- |
cache_test(function(cache) { |
var request = new Request('http://example.com'); |
var response; |
@@ -478,38 +200,4 @@ prepopulated_cache_test(simple_entries, function(cache, entries) { |
}); |
}, 'Cache.match with a network error Response'); |
-// Helpers --- |
- |
-// Run |test_function| with a Cache object as its only parameter. Prior to the |
-// call, the Cache is populated by cache entries from |entries|. The latter is |
-// expected to be an Object mapping arbitrary keys to objects of the form |
-// {request: <Request object>, response: <Response object>}. There's no |
-// guarantee on the order in which entries will be added to the cache. |
-// |
-// |test_function| should return a Promise that can be used with promise_test. |
-function prepopulated_cache_test(entries, test_function, description) { |
- cache_test(function(cache) { |
- var p = Promise.resolve(); |
- var hash = {}; |
- entries.forEach(function(entry) { |
- p = p.then(function() { |
- return cache.put(entry.request.clone(), |
- entry.response.clone()) |
- .catch(function(e) { |
- assert_unreached('Test setup failed for entry ' + |
- entry.name + ': ' + e); |
- }); |
- }); |
- hash[entry.name] = entry; |
- }); |
- p = p.then(function() { |
- assert_equals(Object.keys(hash).length, entries.length); |
- }); |
- |
- return p.then(function() { |
- return test_function(cache, hash); |
- }); |
- }, description); |
-} |
- |
done(); |