// META: script=/common/utils.js const sw_url = location.pathname.replace(/[^/]*$/, '') + "./resources/sharedworker-partitioning-helper.js"; promise_test(async t => { // Create 4 iframes (two normal and two anonymous ones) and create // a shared worker with the same url in all of them. // // Creating the same shared worker again with the same url is a // no-op. However, anonymous iframes get partitioned shared workers, // so we should have a total of 2 shared workers at the end (one for // the normal iframes and one for the anonymous ones). let iframes = await Promise.all([ { name: "normal", anonymous: false}, { name: "normal_control", anonymous: false}, { name: "anonymous", anonymous: true}, { name: "anonymous_control", anonymous: true}, ].map(async ({name, anonymous}) => { let iframe = await new Promise(resolve => { let iframe = document.createElement('iframe'); iframe.onload = () => resolve(iframe); iframe.src = '/common/blank.html'; if (anonymous) iframe.anonymous = true; document.body.append(iframe); }); let sw = new iframe.contentWindow.SharedWorker(sw_url); return { iframe: iframe, name: name, sw: sw }; })); // Ping each worker telling him which iframe it belongs to. await Promise.all(iframes.map(iframe => { iframe.sw.port.postMessage({ action: 'record', from: iframe.name}); return new Promise(resolve => { iframe.sw.port.onmessage = event => { if (event.data.ack === iframe.name) resolve(); } }); })); // Ping each (iframe, sharedworker) asking for which messages it got. let msgs = await Promise.all(iframes.map(iframe => { iframe.sw.port.postMessage({ action: 'retrieve', from: iframe.name }); return new Promise(resolve => { iframe.sw.port.onmessage = event => { if (event.data.ack === iframe.name) resolve(event.data.messages); } }); })); // The "normal" iframe sharedworker belongs to the "normal" and the // "normal_control" iframes. assert_true(!!msgs[0]["normal"] && !!msgs[0]["normal_control"] && !msgs[0]["anonymous"] && !msgs[0]["anonymous_control"], 'The "normal" iframe\'s sharedworker should return ' + '{"normal": true, "normal_control": true}, ' + 'but instead returned ' + JSON.stringify(msgs[0])); // The "normal_control" iframe shares the same sharedworker as the "normal" // iframe. assert_true(!!msgs[1]["normal"] && !!msgs[1]["normal_control"] && !msgs[1]["anonymous"] && !msgs[1]["anonymous_control"], 'The "normal_control" iframe\'s sharedworker should return ' + '{"normal": true, "normal_control": true}, ' + 'but instead returned ' + JSON.stringify(msgs[1])); // The "anonymous" iframe sharedworker belongs to the "anonymous" and the // "anonymous_control" iframes. assert_true(!msgs[2]["normal"] && !msgs[2]["normal_control"] && !!msgs[2]["anonymous"] && !!msgs[2]["anonymous_control"], 'The "anonymous" iframe\'s sharedworker should return ' + '{"anonymous": true, "anonymous_control": true}, ' + 'but instead returned ' + JSON.stringify(msgs[2])); // The "anonymous_control" iframe shares the same sharedworker as // the "anonymous" iframe. assert_true(!msgs[3]["normal"] && !msgs[3]["normal_control"] && !!msgs[3]["anonymous"] && !!msgs[3]["anonymous_control"], 'The "anonymous_control" iframe\'s sharedworker should return ' + '{"anonymous": true, "anonymous_control": true}, ' + 'but instead returned ' + JSON.stringify(msgs[3])); }, "Anonymous iframes get partitioned shared workers.");