store senders instead of buffering messages

This commit is contained in:
Rahul Sharma 2016-08-24 23:22:02 +05:30
parent 0996b38ade
commit 9dcb7348a2
17 changed files with 193 additions and 188 deletions

View file

@ -8,6 +8,5 @@
<div>
<a href="http://github.com/servo/servo">Servo Project</a>
</div>
</body>
</html>

View file

@ -0,0 +1,3 @@
function test_importScripts() {
console.log('Hi from dummy.js');
}

View file

@ -1,11 +1,11 @@
self.addEventListener('activate', function(e) {
console.log("iframe service worker active");
console.log("iframe service worker active");
});
self.addEventListener('fetch', function(e) {
console.log("A fetch event detected by /iframe service worker");
console.log("A fetch event detected by /iframe service worker");
});
self.addEventListener('message', function(e) {
console.log('Post message payload ' + e.data.msg);
console.log(e.data.payload.msg + ' from '+ e.data.payload.worker_id);
})

View file

@ -16,43 +16,56 @@
<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>
<button onclick="post_message_root()">Msg to Root service worker</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);
document.getElementById('iframe_sw').src = 'demo_iframe.html';
var payload = { msg: 'Hi from /iframe service worker' };
// The delay is due to the sender being set in the service worker object after the scope starts.
// This won't be needed when service workers are wrapped with Promises.
setTimeout(function() {
navigator.serviceWorker.controller.postMessage(payload);
}, 1000);
post_message('/demo_iframe');
function register_zero() {
var reg = navigator.serviceWorker.register('sw.js', { 'scope': './' });
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);
}
function post_message_root() {
// Testing repeated calls of postMessage
for(var i=0;i<100;i++){
navigator.serviceWorker.controller.postMessage({num:'Dummy message count: '+i});
}
}
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);
post_message('/dashboard');
}
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);
post_message('/profile');
}
navigator.serviceWorker.addEventListener('controllerchange', function(e) {
console.log("active Service Worker changed");
console.log("navigator.serviceWorker.controller changed");
});
function post_message(worker_id) {
navigator.serviceWorker.controller.postMessage({
payload:{
msg:'Hi there! This is a dummy message for testing of postMessage calls from Service Workers',
worker_id:worker_id
}
});
}
</script>
</body>
</html>

View file

@ -0,0 +1,11 @@
self.addEventListener('activate', function(e) {
console.log('Root service worker active');
});
self.addEventListener('fetch', function(e) {
console.log("A fetch event detected by / service worker");
});
self.addEventListener('message', function(e) {
console.log(e.data.num);
})

View file

@ -1,9 +1,11 @@
importScripts('dashboard_helper.js');
self.addEventListener('activate', function(e) {
status_from_dashboard();
console.log('Dashboard service worker active');
});
self.addEventListener('fetch', function(e) {
console.log("A fetch event detected by /dashboard service worker");
});
console.log("A fetch event detected by /dashboard service worker");
});
self.addEventListener('message', function(e) {
console.log(e.data.payload.msg + ' from '+ e.data.payload.worker_id);
})

View file

@ -1,8 +1,12 @@
self.addEventListener('activate', function(e) {
console.log("profile service worker active");
console.log("profile service worker active");
});
self.addEventListener('fetch', function(e) {
console.log("A fetch event detected by /profile service worker");
});
console.log("A fetch event detected by /profile service worker");
});
self.addEventListener('message', function(e) {
console.log(e.data.payload.msg + ' from '+ e.data.payload.worker_id);
})