<!doctype html>
<html>
<head>
<title>Notifications: the fetch handler handles the request for the icon.</title>
<script src="../resources/testharness.js"></script>
<script src="../resources/testharnessreport.js"></script>
<script src="../serviceworker/resources/test-helpers.js"></script>
<script src="resources/test-helpers.js"></script>
</head>
<body>
<script>
// Tests that the request for the notification icon is handled by the fetch event handler for
// a persistent notification shown by the service worker.
promise_test(test => {
var scope = './';
var script = 'instrumentation-service-worker.js';
var port;
var iconPath = '/resources/square20.png';
testRunner.setPermission('notifications', 'granted', location.origin, location.origin);
return getActiveServiceWorkerWithMessagePort(test, script, scope).then(info => {
port = info.port;
assert_true(!!navigator.serviceWorker.controller, 'The page must be controlled.');
// (1) Display a persistent notification from a service worker context.
return sendCommand(port, {
command: 'show',
title: 'Title',
options: { icon: iconPath }
});
}).then(data => {
assert_true(data.success);
return sendCommand(port, { command: 'get-fetch-history' });
}).then(data => {
// (2) Verify that the icon request passed through the fetch event handler.
// TODO(mvanouwerkerk): The fetch should go through the worker - crbug.com/605917.
assert_equals(data.fetchHistory.length, 0);
});
}, 'The request for the notification icon is handled by the fetch event handler.');
</script>
</body>
</html>