From 36d22d82aa202bb199967e9512281e9a53db42c9 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 21:33:14 +0200 Subject: Adding upstream version 115.7.0esr. Signed-off-by: Daniel Baumann --- .../tabs/browser_origin_attrs_in_remote_type.js | 106 +++++++++++++++++++++ 1 file changed, 106 insertions(+) create mode 100644 browser/base/content/test/tabs/browser_origin_attrs_in_remote_type.js (limited to 'browser/base/content/test/tabs/browser_origin_attrs_in_remote_type.js') diff --git a/browser/base/content/test/tabs/browser_origin_attrs_in_remote_type.js b/browser/base/content/test/tabs/browser_origin_attrs_in_remote_type.js new file mode 100644 index 0000000000..00bdb83cdd --- /dev/null +++ b/browser/base/content/test/tabs/browser_origin_attrs_in_remote_type.js @@ -0,0 +1,106 @@ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +"use strict"; + +/* import-globals-from helper_origin_attrs_testing.js */ +loadTestSubscript("helper_origin_attrs_testing.js"); + +const PATH = "browser/browser/base/content/test/tabs/blank.html"; + +var TEST_CASES = [ + { uri: "https://example.com/" + PATH }, + { uri: "https://example.org/" + PATH }, + { uri: "about:preferences" }, + { uri: "about:config" }, + // file:// uri will be added in setup() +]; + +// 3 container tabs, 1 regular tab and 1 private tab +const NUM_PAGES_OPEN_FOR_EACH_TEST_CASE = 5; +var remoteTypes; + +add_setup(async function () { + await SpecialPowers.pushPrefEnv({ + set: [ + ["privacy.userContext.enabled", true], + // don't preload tabs so we don't have extra XULFrameLoaderCreated events + // firing + ["browser.newtab.preload", false], + ], + }); + requestLongerTimeout(5); + + // Add a file:// uri + let dir = getChromeDir(getResolvedURI(gTestPath)); + dir.append("blank.html"); + // The file can be a symbolic link on local build. Normalize it to make sure + // the path matches to the actual URI opened in the new tab. + dir.normalize(); + const uriString = Services.io.newFileURI(dir).spec; + TEST_CASES.push({ uri: uriString }); +}); + +function setupRemoteTypes() { + remoteTypes = getExpectedRemoteTypes( + gFissionBrowser, + NUM_PAGES_OPEN_FOR_EACH_TEST_CASE + ); + remoteTypes = remoteTypes.concat( + Array(NUM_PAGES_OPEN_FOR_EACH_TEST_CASE).fill("file") + ); // file uri +} + +add_task(async function test_user_identity_simple() { + setupRemoteTypes(); + var currentRemoteType; + + for (let testData of TEST_CASES) { + info(`Will open ${testData.uri} in different tabs`); + // Open uri without a container + info(`About to open a regular page`); + currentRemoteType = remoteTypes.shift(); + let page_regular = await openURIInRegularTab(testData.uri, window); + is( + page_regular.tab.linkedBrowser.remoteType, + currentRemoteType, + "correct remote type" + ); + + // Open the same uri in different user contexts + info(`About to open container pages`); + let containerPages = []; + for ( + var user_context_id = 1; + user_context_id <= NUM_USER_CONTEXTS; + user_context_id++ + ) { + currentRemoteType = remoteTypes.shift(); + let containerPage = await openURIInContainer( + testData.uri, + window, + user_context_id + ); + is( + containerPage.tab.linkedBrowser.remoteType, + currentRemoteType, + "correct remote type" + ); + containerPages.push(containerPage); + } + + // Open the same uri in a private browser + currentRemoteType = remoteTypes.shift(); + let page_private = await openURIInPrivateTab(testData.uri); + let privateRemoteType = page_private.tab.linkedBrowser.remoteType; + is(privateRemoteType, currentRemoteType, "correct remote type"); + + // Close all the tabs + containerPages.forEach(page => { + BrowserTestUtils.removeTab(page.tab); + }); + BrowserTestUtils.removeTab(page_regular.tab); + BrowserTestUtils.removeTab(page_private.tab); + } +}); -- cgit v1.2.3