// META: title=Cache.keys // META: global=window,worker // META: script=./resources/test-helpers.js // META: timeout=long cache_test(cache => { return cache.keys() .then(requests => { assert_equals( requests.length, 0, 'Cache.keys should resolve to an empty array for an empty cache'); }); }, 'Cache.keys() called on an empty cache'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys('not-present-in-the-cache') .then(function(result) { assert_request_array_equals( result, [], 'Cache.keys should resolve with an empty array on failure.'); }); }, 'Cache.keys with no matching entries'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys(entries.a.request.url) .then(function(result) { assert_request_array_equals(result, [entries.a.request], 'Cache.keys should match by URL.'); }); }, 'Cache.keys with URL'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys(entries.a.request) .then(function(result) { assert_request_array_equals( result, [entries.a.request], 'Cache.keys should match by Request.'); }); }, 'Cache.keys with Request'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys(new Request(entries.a.request.url)) .then(function(result) { assert_request_array_equals( result, [entries.a.request], 'Cache.keys should match by Request.'); }); }, 'Cache.keys with new Request'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys(entries.a.request, {ignoreSearch: true}) .then(function(result) { assert_request_array_equals( result, [ entries.a.request, entries.a_with_query.request ], 'Cache.keys with ignoreSearch should ignore the ' + 'search parameters of cached request.'); }); }, 'Cache.keys with ignoreSearch option (request with no search ' + 'parameters)'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys(entries.a_with_query.request, {ignoreSearch: true}) .then(function(result) { assert_request_array_equals( result, [ entries.a.request, entries.a_with_query.request ], 'Cache.keys with ignoreSearch should ignore the ' + 'search parameters of request.'); }); }, 'Cache.keys with ignoreSearch option (request with search parameters)'); cache_test(function(cache) { var request = new Request('http://example.com/'); var head_request = new Request('http://example.com/', {method: 'HEAD'}); var response = new Response('foo'); return cache.put(request.clone(), response.clone()) .then(function() { return cache.keys(head_request.clone()); }) .then(function(result) { assert_request_array_equals( result, [], 'Cache.keys should resolve with an empty array with a ' + 'mismatched method.'); return cache.keys(head_request.clone(), {ignoreMethod: true}); }) .then(function(result) { assert_request_array_equals( result, [ request, ], 'Cache.keys with ignoreMethod should ignore the ' + 'method of request.'); }); }, 'Cache.keys supports ignoreMethod'); cache_test(function(cache) { var vary_request = new Request('http://example.com/c', {headers: {'Cookies': 'is-for-cookie'}}); var vary_response = new Response('', {headers: {'Vary': 'Cookies'}}); var mismatched_vary_request = new Request('http://example.com/c'); return cache.put(vary_request.clone(), vary_response.clone()) .then(function() { return cache.keys(mismatched_vary_request.clone()); }) .then(function(result) { assert_request_array_equals( result, [], 'Cache.keys should resolve with an empty array with a ' + 'mismatched vary.'); return cache.keys(mismatched_vary_request.clone(), {ignoreVary: true}); }) .then(function(result) { assert_request_array_equals( result, [ vary_request, ], 'Cache.keys with ignoreVary should ignore the ' + 'vary of request.'); }); }, 'Cache.keys supports ignoreVary'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys(entries.cat.request.url + '#mouse') .then(function(result) { assert_request_array_equals( result, [ entries.cat.request, ], 'Cache.keys should ignore URL fragment.'); }); }, 'Cache.keys with URL containing fragment'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys('http') .then(function(result) { assert_request_array_equals( result, [], 'Cache.keys should treat query as a URL and not ' + 'just a string fragment.'); }); }, 'Cache.keys with string fragment "http" as query'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys() .then(function(result) { assert_request_array_equals( result, simple_entries.map(entry => entry.request), 'Cache.keys without parameters should match all entries.'); }); }, 'Cache.keys without parameters'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys(undefined) .then(function(result) { assert_request_array_equals( result, simple_entries.map(entry => entry.request), 'Cache.keys with undefined request should match all entries.'); }); }, 'Cache.keys with explicitly undefined request'); cache_test(cache => { return cache.keys(undefined, {}) .then(requests => { assert_equals( requests.length, 0, 'Cache.keys should resolve to an empty array for an empty cache'); }); }, 'Cache.keys with explicitly undefined request and empty options'); prepopulated_cache_test(vary_entries, function(cache, entries) { return cache.keys() .then(function(result) { assert_request_array_equals( result, [ entries.vary_cookie_is_cookie.request, entries.vary_cookie_is_good.request, entries.vary_cookie_absent.request, ], 'Cache.keys without parameters should match all entries.'); }); }, 'Cache.keys without parameters and VARY entries'); prepopulated_cache_test(simple_entries, function(cache, entries) { return cache.keys(new Request(entries.cat.request.url, {method: 'HEAD'})) .then(function(result) { assert_request_array_equals( result, [], 'Cache.keys should not match HEAD request unless ignoreMethod ' + 'option is set.'); }); }, 'Cache.keys with a HEAD Request'); done();