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

Unified Diff: LayoutTests/http/tests/serviceworker/resources/fetch-access-control-worker.js

Issue 399543002: [ServiceWorker] Make fetch() method better conformance with the spec. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: incorporated falken's comment Created 6 years, 5 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/fetch-access-control-worker.js
diff --git a/LayoutTests/http/tests/serviceworker/resources/fetch-access-control-worker.js b/LayoutTests/http/tests/serviceworker/resources/fetch-access-control-worker.js
new file mode 100644
index 0000000000000000000000000000000000000000..1cfb4c4274d203f86816ff966d233c687d5fc964
--- /dev/null
+++ b/LayoutTests/http/tests/serviceworker/resources/fetch-access-control-worker.js
@@ -0,0 +1,99 @@
+var port = undefined;
+var isTestTargetFetch = false;
+
+self.onmessage = function(e) {
+ var message = e.data;
+ if ('port' in message) {
+ port = message.port;
+ } else if (message.msg === 'START TEST CASE') {
+ isTestTargetFetch = true;
+ port.postMessage({msg: 'READY'});
+ }
+};
+
+function getQueryParams(url) {
+ var search = (new URL(url)).search;
+ if (!search) {
+ return {};
+ }
+ var ret = {};
+ var params = search.substring(1).split('&');
+ params.forEach(function(param) {
+ var element = param.split('=');
+ ret[decodeURIComponent(element[0])] = decodeURIComponent(element[1]);
+ });
+ return ret;
+}
+
+function getRequestInit(params) {
+ var init = {};
+ if (params['method']) {
+ init['method'] = params['method'];
+ }
+ if (params['mode']) {
+ init['mode'] = params['mode'];
+ }
+ if (params['credentials']) {
+ init['credentials'] = params['credentials'];
+ }
+ if (params['headers'] === 'CUSTOM') {
+ init['headers'] = {"X-ServiceWorker-Test": "test"};
+ } else if (params['headers'] === '{}') {
+ init['headers'] = {};
+ }
+ return init;
+}
+
+function headersToArray(headers) {
+ var ret = [];
+ headers.forEach(function(value, key) {
+ ret.push([key, value]);
+ });
+ return ret;
+}
+
+self.addEventListener('fetch', function(event) {
+ var originalURL = event.request.url;
+ if (!isTestTargetFetch) {
+ // Don't handle the event when it is not the test target fetch such as a
+ // redirected fetch or for the iframe html.
+ return;
+ }
+ isTestTargetFetch = false;
+ var params = getQueryParams(originalURL);
+ var init = getRequestInit(params);
+ var url = params['url'];
+ if (params['ignore']) {
+ port.postMessage({fetchResult: 'ignored'});
+ return;
+ }
+ event.respondWith(new Promise(function(resolve, reject) {
+ try {
+ var request = event.request;
+ if (url) {
+ request = new Request(url, init);
+ } else if (!params['noChange']) {
+ request = new Request(request, init);
+ }
+ fetch(request)
+ .then(function(res) {
+ // Send the result to fetch-access-control.html.
+ port.postMessage({fetchResult: 'resolved',
+ hasBody: !!res.body,
+ headers: headersToArray(res.headers),
+ type: res.type,
+ originalURL: originalURL});
+ resolve(res);
+ })
+ .catch(function(e) {
+ // Send the result to fetch-access-control.html.
+ port.postMessage({fetchResult: 'rejected'});
+ reject();
+ });
+ } catch (e) {
+ // Send the result to fetch-access-control.html.
+ port.postMessage({fetchResult: 'error'});
+ reject();
+ }
+ }));
+ });

Powered by Google App Engine
This is Rietveld 408576698