diff --git a/service-workers/service-worker/resources/scope1/redirect.py b/service-workers/service-worker/resources/scope1/redirect.py new file mode 100644 index 00000000000000..0663ca0ed04d90 --- /dev/null +++ b/service-workers/service-worker/resources/scope1/redirect.py @@ -0,0 +1,5 @@ +import os +import sys +# Use the file from the parent directory. +sys.path.append(os.path.dirname(os.path.dirname(__file__))) +from redirect import main diff --git a/service-workers/service-worker/resources/scope2/worker_interception_redirect_webworker.py b/service-workers/service-worker/resources/scope2/worker_interception_redirect_webworker.py new file mode 100644 index 00000000000000..99db1343bad2a8 --- /dev/null +++ b/service-workers/service-worker/resources/scope2/worker_interception_redirect_webworker.py @@ -0,0 +1,5 @@ +import os +import sys +# Use the file from the parent directory. +sys.path.append(os.path.dirname(os.path.dirname(__file__))) +from worker_interception_redirect_webworker import main diff --git a/service-workers/service-worker/resources/worker-interception-redirect-serviceworker.js b/service-workers/service-worker/resources/worker-interception-redirect-serviceworker.js new file mode 100644 index 00000000000000..2b9e551d29b966 --- /dev/null +++ b/service-workers/service-worker/resources/worker-interception-redirect-serviceworker.js @@ -0,0 +1,41 @@ +let name; +if (self.registration.scope.indexOf('scope1') != -1) + name = 'sw1'; +if (self.registration.scope.indexOf('scope2') != -1) + name = 'sw2'; + + +self.addEventListener('fetch', evt => { + // There are three types of requests this service worker handles. + + // (1) The first request for the worker, which will redirect elsewhere. + + // "redirect.py" means to test network redirect, so let network handle it. + if (evt.request.url.indexOf('redirect.py') != -1) { + return; + } + + // "sw-redirect" means to test service worker redirect, so respond with a + // redirect. + if (evt.request.url.indexOf('sw-redirect') != -1) { + const url = new URL(evt.request.url); + const redirect_to = url.searchParams.get('Redirect'); + evt.respondWith(Response.redirect(redirect_to)); + return; + } + + + // (2) After redirect, the request is for a "webworker.py" URL. + // Add a search parameter to indicate this service worker handled the + // final request for the worker. + if (evt.request.url.indexOf('webworker.py') != -1) { + const greeting = encodeURIComponent(`${name} saw the request for the worker script`); + evt.respondWith(fetch(`worker_interception_redirect_webworker.py?greeting=${greeting}`)); + } + + // (3) The worker does a fetch() to simple.txt. Indicate that this service + // worker handled the request. + if (evt.request.url.indexOf('simple.txt') != -1) { + evt.respondWith(new Response(`${name} saw the fetch from the worker`)); + } +}); diff --git a/service-workers/service-worker/resources/worker-interception-redirect-webworker.js b/service-workers/service-worker/resources/worker-interception-redirect-webworker.js new file mode 100644 index 00000000000000..62ace2f3ade9e9 --- /dev/null +++ b/service-workers/service-worker/resources/worker-interception-redirect-webworker.js @@ -0,0 +1,32 @@ +// This is the (shared or dedicated) worker file for the +// worker-controlled-redirect test. It should be served by the corresponding +// .py file instead of being served directly. + +function get_resources_path() { + var url = new URL('.', self.location); + while (!url.pathname.endsWith('/resources/')) { + url = new URL('..', url); + } + return url; +} + +const base_url = get_resources_path(); + +// This greeting text is meant to be injected by the python script that serves +// this file, to indicate how the script was served (from network or from +// service worker). +let greeting = '%GREETING_TEXT%'; +if (!greeting) + greeting = 'the shared worker script was served from network'; + +self.onconnect = function(e) { + var port = e.ports[0]; + port.postMessage(greeting); + + port.addEventListener('message', function(e) { + var target = new URL('simple.txt', base_url); + fetch(target).then(r => r.text()).then(result => port.postMessage('fetched: ' + result)); + }); + + port.start(); +}; diff --git a/service-workers/service-worker/resources/worker_interception_redirect_webworker.py b/service-workers/service-worker/resources/worker_interception_redirect_webworker.py new file mode 100644 index 00000000000000..6ab51ee3568ec9 --- /dev/null +++ b/service-workers/service-worker/resources/worker_interception_redirect_webworker.py @@ -0,0 +1,17 @@ +# This serves the worker JavaScript file. It takes a |greeting| request +# parameter to inject into the JavaScript to indicate how the request +# reached the server. +import os +import sys + +def main(request, response): + body = open(os.path.join(os.path.dirname(__file__), "worker-interception-redirect-webworker.js"), "rb").read() + if "greeting" in request.GET: + body = body.replace("%GREETING_TEXT%", request.GET["greeting"]) + else: + body = body.replace("%GREETING_TEXT%", "") + + headers = [] + headers.append(("Content-Type", "text/javascript")) + + return headers, body diff --git a/service-workers/service-worker/worker-interception-redirect.https.html b/service-workers/service-worker/worker-interception-redirect.https.html new file mode 100644 index 00000000000000..4505a7594389ee --- /dev/null +++ b/service-workers/service-worker/worker-interception-redirect.https.html @@ -0,0 +1,162 @@ + +Service Worker: controlling a SharedWorker + + + + + +