mirror of
https://github.com/servo/servo.git
synced 2025-08-07 14:35:33 +01:00
Dispatch events to service worker object and refactor html tests
This commit is contained in:
parent
2aa257f603
commit
1b29dfb8ab
11 changed files with 55 additions and 21 deletions
Binary file not shown.
Before Width: | Height: | Size: 62 KiB |
3
tests/html/service-worker/dashboard_helper.js
Normal file
3
tests/html/service-worker/dashboard_helper.js
Normal file
|
@ -0,0 +1,3 @@
|
|||
function status_from_dashboard() {
|
||||
console.log("Dashboard Service worker is active");
|
||||
}
|
|
@ -2,7 +2,7 @@
|
|||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>An iframe</title>
|
||||
<title>Servo Browser Engine</title>
|
||||
</head>
|
||||
<body>
|
||||
<div>
|
||||
|
|
|
@ -1 +0,0 @@
|
|||
console.log("dummy test file");
|
|
@ -1 +1,7 @@
|
|||
console.log("iframe service worker active");
|
||||
self.addEventListener('activate', function(e) {
|
||||
console.log("iframe service worker active");
|
||||
});
|
||||
|
||||
self.addEventListener('fetch', function(e) {
|
||||
console.log("A fetch event detected by /iframe service worker");
|
||||
});
|
|
@ -6,38 +6,46 @@
|
|||
</head>
|
||||
<body>
|
||||
<p>This page tests the registration and initialization of Service Workers in Servo.</p>
|
||||
<div id="registration">
|
||||
<a href="/dashboard-page.html">Go to Dashboard</a>
|
||||
<a href="/profile.html">Go to Profile</a>
|
||||
|
||||
<div id="sw_demo">
|
||||
<iframe id="iframe_sw" width="" height="200"></iframe>
|
||||
<br>
|
||||
<button onclick="register_zero()">Register for Root</button>
|
||||
<button onclick="register_one()">Register for Dashboard</button>
|
||||
<button onclick="register_two()">Register for Profile</button>
|
||||
<a href="/dashboard-page.html">Go to Dashboard</a>
|
||||
<a href="/profile.html">Go to Profile</a>
|
||||
<br>
|
||||
<button onclick="register_zero()">Register for Root (/)</button>
|
||||
<button onclick="register_one()">Register for Dashboard (/dashboard)</button>
|
||||
<button onclick="register_two()">Register for Profile (/profile)</button>
|
||||
</div>
|
||||
|
||||
<script>
|
||||
var reg = navigator.serviceWorker.register('iframe_sw.js', { 'scope': '/demo_iframe.html' });
|
||||
console.log("From client worker registered: ", navigator.serviceWorker.controller);
|
||||
console.log("Registered script source: ", navigator.serviceWorker.controller.scriptURL);
|
||||
console.log("Registered script source: "+ navigator.serviceWorker.controller.scriptURL);
|
||||
document.getElementById('iframe_sw').src = 'demo_iframe.html';
|
||||
|
||||
function register_zero() {
|
||||
var reg = navigator.serviceWorker.register('sw.js', { 'scope': './' });
|
||||
console.log("From client worker registered: ", navigator.serviceWorker.controller);
|
||||
console.log("Registered script source: ", navigator.serviceWorker.controller.scriptURL);
|
||||
console.log("Registered script source: "+ navigator.serviceWorker.controller.scriptURL);
|
||||
}
|
||||
|
||||
function register_one() {
|
||||
var reg = navigator.serviceWorker.register('sw_dashboard.js', { 'scope': '/dashboard' });
|
||||
console.log("From client worker registered: ", navigator.serviceWorker.controller);
|
||||
console.log("Registered script source: ", navigator.serviceWorker.controller.scriptURL);
|
||||
console.log("Registered script source: "+ navigator.serviceWorker.controller.scriptURL);
|
||||
}
|
||||
|
||||
function register_two() {
|
||||
var reg = navigator.serviceWorker.register('sw_profile.js', { 'scope': '/profile' });
|
||||
console.log("From client worker registered: ", navigator.serviceWorker.controller);
|
||||
console.log("Registered script source: ", navigator.serviceWorker.controller.scriptURL);
|
||||
console.log("Registered script source: "+ navigator.serviceWorker.controller.scriptURL);
|
||||
}
|
||||
|
||||
navigator.serviceWorker.addEventListener('controllerchange', function(e) {
|
||||
console.log("active Service Worker changed");
|
||||
});
|
||||
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
|
@ -1 +0,0 @@
|
|||
console.log("root service worker: active");
|
|
@ -1,2 +1,9 @@
|
|||
importScripts('dummy.js');
|
||||
console.log("dashboard service worker: active");
|
||||
importScripts('dashboard_helper.js');
|
||||
|
||||
self.addEventListener('activate', function(e) {
|
||||
status_from_dashboard();
|
||||
});
|
||||
|
||||
self.addEventListener('fetch', function(e) {
|
||||
console.log("A fetch event detected by /dashboard service worker");
|
||||
});
|
|
@ -1 +1,8 @@
|
|||
console.log("profile service worker: active");
|
||||
|
||||
self.addEventListener('activate', function(e) {
|
||||
console.log("profile service worker active");
|
||||
});
|
||||
|
||||
self.addEventListener('fetch', function(e) {
|
||||
console.log("A fetch event detected by /profile service worker");
|
||||
});
|
Loading…
Add table
Add a link
Reference in a new issue