forked from mirrors/gecko-dev
Automatic changes by ESLint, except for manual corrections for .xml files. Differential Revision: https://phabricator.services.mozilla.com/D4439 --HG-- extra : moz-landing-system : lando
138 lines
4.5 KiB
JavaScript
138 lines
4.5 KiB
JavaScript
const BASE_ORIGIN = "http://example.com";
|
|
const URI = BASE_ORIGIN +
|
|
"/browser/browser/components/contextualidentity/test/browser/empty_file.html";
|
|
|
|
// Opens `uri' in a new tab with the provided userContextId and focuses it.
|
|
// Returns the newly opened tab and browser.
|
|
async function openTabInUserContext(uri, userContextId) {
|
|
// open the tab in the correct userContextId
|
|
let tab = BrowserTestUtils.addTab(gBrowser, uri, {userContextId});
|
|
|
|
// select tab and make sure its browser is focused
|
|
gBrowser.selectedTab = tab;
|
|
tab.ownerGlobal.focus();
|
|
|
|
let browser = gBrowser.getBrowserForTab(tab);
|
|
await BrowserTestUtils.browserLoaded(browser);
|
|
return {tab, browser};
|
|
}
|
|
|
|
// Opens `uri' in a new <iframe mozbrowser> with the provided userContextId.
|
|
// Returns the newly opened browser.
|
|
async function addBrowserFrameInUserContext(uri, userContextId) {
|
|
// Create a browser frame with the user context and uri
|
|
const browser = document.createElementNS("http://www.w3.org/1999/xhtml", "iframe");
|
|
browser.setAttribute("remote", "true");
|
|
browser.setAttribute("usercontextid", userContextId);
|
|
browser.setAttribute("mozbrowser", "true");
|
|
// `noisolation = true` means `OA.mInIsolatedMozBrowser = false` which matches
|
|
// the default for a XUL browser. It is indepedent from user contexts.
|
|
browser.setAttribute("noisolation", "true");
|
|
browser.setAttribute("src", uri);
|
|
gBrowser.tabpanels.appendChild(browser);
|
|
|
|
// Create a XUL browser-like API expected by test helpers
|
|
Object.defineProperty(browser, "messageManager", {
|
|
get() {
|
|
return browser.frameLoader.messageManager;
|
|
},
|
|
configurable: true,
|
|
enumerable: true,
|
|
});
|
|
|
|
await browserFrameLoaded(browser);
|
|
|
|
return { browser };
|
|
}
|
|
|
|
function browserFrameLoaded(browser) {
|
|
const mm = browser.messageManager;
|
|
return new Promise(resolve => {
|
|
const eventName = "browser-test-utils:loadEvent";
|
|
mm.addMessageListener(eventName, function onLoad(msg) {
|
|
if (msg.target != browser) {
|
|
return;
|
|
}
|
|
mm.removeMessageListener(eventName, onLoad);
|
|
resolve(msg.data.internalURL);
|
|
});
|
|
});
|
|
}
|
|
|
|
function removeBrowserFrame({ browser }) {
|
|
browser.remove();
|
|
// Clean up Browser API parent-side data
|
|
delete window._browserElementParents;
|
|
}
|
|
|
|
async function runTestForReceiver(receiver) {
|
|
let channelName = "contextualidentity-broadcastchannel";
|
|
|
|
// reflect the received message on title
|
|
await ContentTask.spawn(receiver.browser, channelName,
|
|
function(name) {
|
|
content.window.testPromise = new content.window.Promise(resolve => {
|
|
content.window.bc = new content.window.BroadcastChannel(name);
|
|
content.window.bc.onmessage = function(e) {
|
|
content.document.title += e.data;
|
|
resolve();
|
|
};
|
|
});
|
|
}
|
|
);
|
|
|
|
let sender1 = await openTabInUserContext(URI, 1);
|
|
let sender2 = await openTabInUserContext(URI, 2);
|
|
sender1.message = "Message from user context #1";
|
|
sender2.message = "Message from user context #2";
|
|
|
|
// send a message from a tab in different user context first
|
|
// then send a message from a tab in the same user context
|
|
for (let sender of [sender1, sender2]) {
|
|
await ContentTask.spawn(
|
|
sender.browser,
|
|
{ name: channelName, message: sender.message },
|
|
function(opts) {
|
|
let bc = new content.window.BroadcastChannel(opts.name);
|
|
bc.postMessage(opts.message);
|
|
});
|
|
}
|
|
|
|
// Since sender1 sends before sender2, if the title is exactly
|
|
// sender2's message, sender1's message must've been blocked
|
|
await ContentTask.spawn(receiver.browser, sender2.message,
|
|
async function(message) {
|
|
await content.window.testPromise.then(function() {
|
|
is(content.document.title, message,
|
|
"should only receive messages from the same user context");
|
|
});
|
|
}
|
|
);
|
|
|
|
gBrowser.removeTab(sender1.tab);
|
|
gBrowser.removeTab(sender2.tab);
|
|
}
|
|
|
|
add_task(async function setup() {
|
|
// make sure userContext is enabled.
|
|
await SpecialPowers.pushPrefEnv({"set": [
|
|
["privacy.userContext.enabled", true],
|
|
]});
|
|
});
|
|
|
|
add_task(async function test() {
|
|
info("Checking broadcast channel with browser tab receiver");
|
|
let receiver = await openTabInUserContext(URI, 2);
|
|
await runTestForReceiver(receiver);
|
|
gBrowser.removeTab(receiver.tab);
|
|
});
|
|
|
|
add_task(async function test() {
|
|
info("Checking broadcast channel with <iframe mozbrowser> receiver");
|
|
await SpecialPowers.pushPrefEnv({"set": [
|
|
["dom.mozBrowserFramesEnabled", true],
|
|
]});
|
|
let receiver = await addBrowserFrameInUserContext(URI, 2);
|
|
await runTestForReceiver(receiver);
|
|
removeBrowserFrame(receiver);
|
|
});
|