summaryrefslogtreecommitdiffstats
path: root/devtools/client/netmonitor/test/browser_net_security-redirect.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 17:32:43 +0000
commit6bf0a5cb5034a7e684dcc3500e841785237ce2dd (patch)
treea68f146d7fa01f0134297619fbe7e33db084e0aa /devtools/client/netmonitor/test/browser_net_security-redirect.js
parentInitial commit. (diff)
downloadthunderbird-upstream.tar.xz
thunderbird-upstream.zip
Adding upstream version 1:115.7.0.upstream/1%115.7.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--devtools/client/netmonitor/test/browser_net_security-redirect.js67
1 files changed, 67 insertions, 0 deletions
diff --git a/devtools/client/netmonitor/test/browser_net_security-redirect.js b/devtools/client/netmonitor/test/browser_net_security-redirect.js
new file mode 100644
index 0000000000..3ab7211fe4
--- /dev/null
+++ b/devtools/client/netmonitor/test/browser_net_security-redirect.js
@@ -0,0 +1,67 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"use strict";
+
+/**
+ * Test a http -> https redirect shows secure icon only for redirected https
+ * request.
+ */
+
+add_task(async function () {
+ // This test explicitly asserts http -> https redirects.
+ await pushPref("dom.security.https_first", false);
+
+ const { tab, monitor } = await initNetMonitor(CUSTOM_GET_URL, {
+ requestCount: 1,
+ });
+ const { document, store, windowRequire } = monitor.panelWin;
+ const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
+
+ store.dispatch(Actions.batchEnable(false));
+
+ const wait = waitForNetworkEvents(monitor, 2);
+ await SpecialPowers.spawn(
+ tab.linkedBrowser,
+ [HTTPS_REDIRECT_SJS],
+ async function (url) {
+ content.wrappedJSObject.performRequests(1, url);
+ }
+ );
+ await wait;
+
+ is(
+ store.getState().requests.requests.length,
+ 2,
+ "There were two requests due to redirect."
+ );
+
+ const [
+ initialDomainSecurityIcon,
+ initialUrlSecurityIcon,
+ redirectDomainSecurityIcon,
+ redirectUrlSecurityIcon,
+ ] = document.querySelectorAll(".requests-security-state-icon");
+
+ ok(
+ initialDomainSecurityIcon.classList.contains("security-state-insecure"),
+ "Initial request was marked insecure for domain column."
+ );
+
+ ok(
+ redirectDomainSecurityIcon.classList.contains("security-state-secure"),
+ "Redirected request was marked secure for domain column."
+ );
+
+ ok(
+ initialUrlSecurityIcon.classList.contains("security-state-insecure"),
+ "Initial request was marked insecure for URL column."
+ );
+
+ ok(
+ redirectUrlSecurityIcon.classList.contains("security-state-secure"),
+ "Redirected request was marked secure for URL column."
+ );
+
+ await teardown(monitor);
+});