From 6bf0a5cb5034a7e684dcc3500e841785237ce2dd Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 19:32:43 +0200 Subject: Adding upstream version 1:115.7.0. Signed-off-by: Daniel Baumann --- .../test/siteIdentity/browser_no_mcb_for_onions.js | 41 ++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 browser/base/content/test/siteIdentity/browser_no_mcb_for_onions.js (limited to 'browser/base/content/test/siteIdentity/browser_no_mcb_for_onions.js') diff --git a/browser/base/content/test/siteIdentity/browser_no_mcb_for_onions.js b/browser/base/content/test/siteIdentity/browser_no_mcb_for_onions.js new file mode 100644 index 0000000000..4a5c65b125 --- /dev/null +++ b/browser/base/content/test/siteIdentity/browser_no_mcb_for_onions.js @@ -0,0 +1,41 @@ +/* Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/publicdomain/zero/1.0/ */ + +// The test loads a HTTPS web page with active content from HTTP .onion URLs +// and makes sure that the mixed content flags on the docshell are not set. +// +// Note that the URLs referenced within the test page intentionally use the +// unassigned port 8 because we don't want to actually load anything, we just +// want to check that the URLs are not blocked. + +const TEST_URL = + getRootDirectory(gTestPath).replace( + "chrome://mochitests/content", + "https://example.com" + ) + "test_no_mcb_for_onions.html"; + +const PREF_BLOCK_DISPLAY = "security.mixed_content.block_display_content"; +const PREF_BLOCK_ACTIVE = "security.mixed_content.block_active_content"; +const PREF_ONION_ALLOWLIST = "dom.securecontext.allowlist_onions"; + +add_task(async function allowOnionMixedContent() { + registerCleanupFunction(function () { + gBrowser.removeCurrentTab(); + }); + + await SpecialPowers.pushPrefEnv({ set: [[PREF_BLOCK_DISPLAY, true]] }); + await SpecialPowers.pushPrefEnv({ set: [[PREF_BLOCK_ACTIVE, true]] }); + await SpecialPowers.pushPrefEnv({ set: [[PREF_ONION_ALLOWLIST, true]] }); + + const tab = await BrowserTestUtils.openNewForegroundTab( + gBrowser, + TEST_URL + ).catch(console.error); + const browser = gBrowser.getBrowserForTab(tab); + + await assertMixedContentBlockingState(browser, { + activeBlocked: false, + activeLoaded: false, + passiveLoaded: false, + }); +}); -- cgit v1.2.3