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 --- .../referrer/browser_referrer_click_pinned_tab.js | 82 ++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 browser/base/content/test/referrer/browser_referrer_click_pinned_tab.js (limited to 'browser/base/content/test/referrer/browser_referrer_click_pinned_tab.js') diff --git a/browser/base/content/test/referrer/browser_referrer_click_pinned_tab.js b/browser/base/content/test/referrer/browser_referrer_click_pinned_tab.js new file mode 100644 index 0000000000..2c0d14d687 --- /dev/null +++ b/browser/base/content/test/referrer/browser_referrer_click_pinned_tab.js @@ -0,0 +1,82 @@ +/* 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/. */ + +// We will open a new tab if clicking on a cross domain link in pinned tab +// So, override the tests data in head.js, adding "cross: true". + +_referrerTests = [ + { + // eslint-disable-next-line @microsoft/sdl/no-insecure-url + fromScheme: "http://", + // eslint-disable-next-line @microsoft/sdl/no-insecure-url + toScheme: "http://", + cross: true, + // eslint-disable-next-line @microsoft/sdl/no-insecure-url + result: "http://test1.example.com/", // origin + }, + { + fromScheme: "https://", + // eslint-disable-next-line @microsoft/sdl/no-insecure-url + toScheme: "http://", + cross: true, + result: "", // no referrer when downgrade + }, + { + fromScheme: "https://", + // eslint-disable-next-line @microsoft/sdl/no-insecure-url + toScheme: "http://", + policy: "origin", + cross: true, + result: "https://test1.example.com/", // origin, even on downgrade + }, + { + fromScheme: "https://", + // eslint-disable-next-line @microsoft/sdl/no-insecure-url + toScheme: "http://", + policy: "origin", + rel: "noreferrer", + cross: true, + result: "", // rel=noreferrer trumps meta-referrer + }, + { + fromScheme: "https://", + toScheme: "https://", + policy: "no-referrer", + cross: true, + result: "", // same origin https://test1.example.com/browser + }, + { + // eslint-disable-next-line @microsoft/sdl/no-insecure-url + fromScheme: "http://", + toScheme: "https://", + policy: "no-referrer", + cross: true, + result: "", // cross origin http://test1.example.com + }, +]; + +async function startClickPinnedTabTestCase(aTestNumber) { + info( + "browser_referrer_click_pinned_tab: " + + getReferrerTestDescription(aTestNumber) + ); + let browser = gTestWindow.gBrowser; + + browser.pinTab(browser.selectedTab); + someTabLoaded(gTestWindow).then(function (aNewTab) { + checkReferrerAndStartNextTest( + aTestNumber, + null, + aNewTab, + startClickPinnedTabTestCase + ); + }); + + clickTheLink(gTestWindow, "testlink", {}); +} + +function test() { + requestLongerTimeout(10); // slowwww shutdown on e10s + startReferrerTest(startClickPinnedTabTestCase); +} -- cgit v1.2.3