Commit 0917ff14 authored by horo@chromium.org's avatar horo@chromium.org

Add LayoutTests for the behavior of navigation redirect with Service Worker.

This CL depends on https://codereview.chromium.org/1271733002/ (chromium) and https://codereview.chromium.org/1280733002/ (blink).

BUG=518713,510650

Review URL: https://codereview.chromium.org/1286153003

git-svn-id: svn://svn.chromium.org/blink/trunk@200881 bbb929c8-8fbe-4397-9dbb-9b2b20218538
parent e65ad9b4
<!DOCTYPE html>
<script src="../../resources/get-host-info.js"></script>
<script src="test-helpers.js?pipe=sub"></script>
<script>
var host_info = get_host_info();
var SCOPE = 'navigation-redirect-scope1.php';
var SCRIPT = 'navigation-redirect-worker.js';
var registration;
var worker;
var wait_for_worker_promise = navigator.serviceWorker.getRegistration(SCOPE)
.then(function(reg) {
if (reg)
return reg.unregister();
})
.then(function() {
return navigator.serviceWorker.register(SCRIPT, {scope: SCOPE});
})
.then(function(reg) {
registration = reg;
worker = reg.installing;
return new Promise(function(resolve) {
worker.addEventListener('statechange', function() {
if (worker.state == 'activated')
resolve();
});
});
});
function send_result(message_id, result) {
window.parent.postMessage(
{id: message_id, result: result},
host_info['HTTP_ORIGIN']);
}
function get_intercepted_urls(worker) {
return new Promise(function(resolve) {
var channel = new MessageChannel();
channel.port1.onmessage = function(msg) { resolve(msg.data.urls); };
worker.postMessage({port: channel.port2}, [channel.port2]);
});
}
window.addEventListener('message', on_message, false);
function on_message(e) {
if (e.origin != host_info['HTTP_ORIGIN']) {
console.error('invalid origin: ' + e.origin);
return;
}
if (e.data.message == 'wait_for_worker') {
wait_for_worker_promise.then(function() { send_result(e.data.id, 'ok'); });
} else if (e.data.message == 'get_intercepted_urls') {
get_intercepted_urls(worker)
.then(function(urls) {
send_result(e.data.id, urls);
});
} else if (e.data.message == 'unregister') {
registration.unregister()
.then(function() {
send_result(e.data.id, 'ok');
});
}
}
</script>
<?php
if (isset($_GET['url'])) {
header("HTTP/1.1 302");
$url = $_GET['url'];
header("Location: $url");
exit;
}
?>
<!DOCTYPE html>
<script>
window.parent.postMessage(
{
id: 'last_url',
result: location.href
},
'http://127.0.0.1:8000');
</script>
// TODO(horo): Service worker can be killed at some point during the test. So we
// should use storage API instead of this global variable.
var urls = [];
self.addEventListener('message', function(event) {
event.data.port.postMessage({urls: urls});
urls = [];
});
function get_query_params(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;
}
self.addEventListener('fetch', function(event) {
urls.push(event.request.url)
var params = get_query_params(event.request.url);
if (params['sw'] == 'gen') {
event.respondWith(Response.redirect(params['url']));
} else if (params['sw'] == 'fetch') {
event.respondWith(fetch(event.request));
} else if (params['sw'] == 'opaque') {
event.respondWith(fetch(
new Request(event.request.url, {redirect: 'manual'})));
} else if (params['sw'] == 'opaqueThroughCache') {
var url = event.request.url;
var cache;
event.respondWith(
self.caches.delete(url)
.then(function() { return self.caches.open(url); })
.then(function(c) {
cache = c;
return fetch(new Request(url, {redirect: 'manual'}));
})
.then(function(res) { return cache.put(event.request, res); })
.then(function() { return cache.match(url); }));
}
});
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment