Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(189)

Unified Diff: LayoutTests/http/tests/serviceworker/resources/cache-match-worker.js

Issue 1043213003: Remove redundant serviceworker/cache-* tests (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Re-add fetch-status.php, used by fetch tests in sibling dir Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: LayoutTests/http/tests/serviceworker/resources/cache-match-worker.js
diff --git a/LayoutTests/http/tests/serviceworker/resources/cache-match-worker.js b/LayoutTests/http/tests/serviceworker/resources/cache-match-worker.js
deleted file mode 100644
index 774297c72c89e23ed33ca20a8bd9b5646bcbfeae..0000000000000000000000000000000000000000
--- a/LayoutTests/http/tests/serviceworker/resources/cache-match-worker.js
+++ /dev/null
@@ -1,497 +0,0 @@
-importScripts('worker-testharness.js');
-importScripts('/resources/testharness-helpers.js');
-importScripts('override_assert_object_equals.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('')
- }
-];
-
-// 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) {
- assert_equals(result, undefined,
- 'Cache.match failures should resolve with undefined.');
- });
- }, '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_objects_equals(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(result, entries.a.response,
- 'Cache.match should match by URL.');
- });
- }, 'Cache.match with URL');
-
-prepopulated_cache_test(simple_entries, function(cache, entries) {
- return cache.matchAll(entries.a.request)
- .then(function(result) {
- assert_array_objects_equals(
- 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(result, entries.a.response,
- 'Cache.match should match by Request.');
- });
- }, '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_objects_equals(
- 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(result, entries.a.response,
- 'Cache.match should match by Request.');
- });
- }, 'Cache.match with new Request');
-
-cache_test(function(cache) {
- var request = new Request('https://example.com/foo', {
- method: 'POST',
- body: 'Hello world!'
- });
- var response = new Response('Booyah!', {
- status: 200,
- headers: {'Content-Type': 'text/plain'}
- });
-
- return cache.put(request.clone(), response.clone())
- .then(function() {
- assert_false(
- request.bodyUsed,
- '[https://fetch.spec.whatwg.org/#concept-body-used-flag] ' +
- 'Request.bodyUsed flag should be initially false.');
- })
- .then(function() {
- return cache.match(request);
- })
- .then(function(result) {
- assert_false(request.bodyUsed,
- 'Cache.match should not consume Request body.');
- });
- }, 'Cache.match with Request containing non-empty body');
-
-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) {
- assert_object_in_array(
- result,
- [
- entries.a.response,
- entries.a_with_query.response
- ],
- 'Cache.match with ignoreSearch should ignore the ' +
- 'search parameters of cached request.');
- });
- },
- 'Cache.match with ignoreSearch option (request with no search ' +
- '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) {
- assert_object_in_array(
- result,
- [
- entries.a.response,
- entries.a_with_query.response
- ],
- 'Cache.match with ignoreSearch should ignore the ' +
- 'search parameters of request.');
- });
- },
- '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(result, entries.cat.response,
- 'Cache.match should ignore URL fragment.');
- });
- }, '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(
- result, undefined,
- 'Cache.match should treat query as a URL and not ' +
- 'just a string fragment.');
- });
- }, '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(
- result, entries.secret_cat.response,
- 'Cache.match should not ignore embedded credentials');
- });
- }, '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(
- result,
- [
- entries.vary_wildcard.response,
- entries.vary_cookie_absent.response
- ],
- 'Cache.match should honor "Vary" header.');
- });
- }, '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;
- var request_url = new URL('simple.txt', location.href).href;
- return fetch(request_url)
- .then(function(fetch_result) {
- response = fetch_result;
- assert_equals(
- response.url, request_url,
- '[https://fetch.spec.whatwg.org/#dom-response-url] ' +
- 'Reponse.url should return the URL of the response.');
- return cache.put(request, response.clone());
- })
- .then(function() {
- return cache.match(request.url);
- })
- .then(function(result) {
- assert_object_equals(
- result, response,
- 'Cache.match should return a Response object that has the same ' +
- 'properties as the stored response.');
- return cache.match(response.url);
- })
- .then(function(result) {
- assert_equals(
- result, undefined,
- 'Cache.match should not match cache entry based on response URL.');
- });
- }, 'Cache.match with Request and Response objects with different URLs');
-
-cache_test(function(cache) {
- var request_url = new URL('simple.txt', location.href).href;
- return fetch(request_url)
- .then(function(fetch_result) {
- return cache.put(new Request(request_url), fetch_result);
- })
- .then(function() {
- return cache.match(request_url);
- })
- .then(function(result) {
- return result.text();
- })
- .then(function(body_text) {
- assert_equals(body_text, 'a simple text file\n',
- 'Cache.match should return a Response object with a ' +
- 'valid body.');
- })
- .then(function() {
- return cache.match(request_url);
- })
- .then(function(result) {
- return result.text();
- })
- .then(function(body_text) {
- assert_equals(body_text, 'a simple text file\n',
- 'Cache.match should return a Response object with a ' +
- 'valid body each time it is called.');
- });
- }, 'Cache.match invoked multiple times for the same Request/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);
-}

Powered by Google App Engine
This is Rietveld 408576698