summaryrefslogtreecommitdiffstats
path: root/devtools/client/netmonitor/test/browser_net_req-resp-bodies.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_req-resp-bodies.js
parentInitial commit. (diff)
downloadthunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.tar.xz
thunderbird-6bf0a5cb5034a7e684dcc3500e841785237ce2dd.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 'devtools/client/netmonitor/test/browser_net_req-resp-bodies.js')
-rw-r--r--devtools/client/netmonitor/test/browser_net_req-resp-bodies.js83
1 files changed, 83 insertions, 0 deletions
diff --git a/devtools/client/netmonitor/test/browser_net_req-resp-bodies.js b/devtools/client/netmonitor/test/browser_net_req-resp-bodies.js
new file mode 100644
index 0000000000..49d9bbd2b2
--- /dev/null
+++ b/devtools/client/netmonitor/test/browser_net_req-resp-bodies.js
@@ -0,0 +1,83 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"use strict";
+
+/**
+ * Test if request and response body logging stays on after opening the console.
+ */
+
+add_task(async function () {
+ const {
+ L10N,
+ } = require("resource://devtools/client/netmonitor/src/utils/l10n.js");
+
+ const { tab, monitor } = await initNetMonitor(JSON_LONG_URL, {
+ requestCount: 1,
+ });
+ info("Starting test... ");
+
+ const { document, store, windowRequire } = monitor.panelWin;
+ const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
+ const { getDisplayedRequests, getSortedRequests } = windowRequire(
+ "devtools/client/netmonitor/src/selectors/index"
+ );
+
+ store.dispatch(Actions.batchEnable(false));
+
+ // Perform first batch of requests.
+ await performRequests(monitor, tab, 1);
+
+ await verifyRequest(0);
+
+ // Switch to the webconsole.
+ const onWebConsole = monitor.toolbox.once("webconsole-selected");
+ monitor.toolbox.selectTool("webconsole");
+ await onWebConsole;
+
+ // Switch back to the netmonitor.
+ const onNetMonitor = monitor.toolbox.once("netmonitor-selected");
+ monitor.toolbox.selectTool("netmonitor");
+ await onNetMonitor;
+
+ // Reload debugee.
+ const wait = waitForNetworkEvents(monitor, 1);
+ await reloadBrowser();
+ await wait;
+
+ // Perform another batch of requests.
+ await performRequests(monitor, tab, 1);
+
+ await verifyRequest(1);
+
+ return teardown(monitor);
+
+ async function verifyRequest(index) {
+ const requestItems = document.querySelectorAll(".request-list-item");
+ for (const requestItem of requestItems) {
+ requestItem.scrollIntoView();
+ const requestsListStatus = requestItem.querySelector(".status-code");
+ EventUtils.sendMouseEvent({ type: "mouseover" }, requestsListStatus);
+ await waitUntil(() => requestsListStatus.title);
+ await waitForDOMIfNeeded(requestItem, ".requests-list-timings-total");
+ }
+ verifyRequestItemTarget(
+ document,
+ getDisplayedRequests(store.getState()),
+ getSortedRequests(store.getState())[index],
+ "GET",
+ CONTENT_TYPE_SJS + "?fmt=json-long",
+ {
+ status: 200,
+ statusText: "OK",
+ type: "json",
+ fullMimeType: "text/json; charset=utf-8",
+ size: L10N.getFormatStr(
+ "networkMenu.size.kB",
+ L10N.numberWithDecimals(85975 / 1000, 2)
+ ),
+ time: true,
+ }
+ );
+ }
+});