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 --- .../netmonitor/test/browser_net_post-data.js | 195 +++++++++++++++++++++ 1 file changed, 195 insertions(+) create mode 100644 devtools/client/netmonitor/test/browser_net_post-data.js (limited to 'devtools/client/netmonitor/test/browser_net_post-data.js') diff --git a/devtools/client/netmonitor/test/browser_net_post-data.js b/devtools/client/netmonitor/test/browser_net_post-data.js new file mode 100644 index 0000000000..a2b54b8d62 --- /dev/null +++ b/devtools/client/netmonitor/test/browser_net_post-data.js @@ -0,0 +1,195 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +/** + * Tests if the POST requests display the correct information in the UI. + */ +add_task(async function () { + const { + L10N, + } = require("resource://devtools/client/netmonitor/src/utils/l10n.js"); + + // Set a higher panel height in order to get full CodeMirror content + Services.prefs.setIntPref("devtools.toolbox.footer.height", 600); + + const { tab, monitor } = await initNetMonitor(POST_DATA_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)); + + // Execute requests. + await performRequests(monitor, tab, 2); + + 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); + } + + verifyRequestItemTarget( + document, + getDisplayedRequests(store.getState()), + getSortedRequests(store.getState())[0], + "POST", + SIMPLE_SJS + "?foo=bar&baz=42&type=urlencoded", + { + status: 200, + statusText: "Och Aye", + type: "plain", + fullMimeType: "text/plain; charset=utf-8", + size: L10N.getFormatStrWithNumbers("networkMenu.sizeB", 12), + time: true, + } + ); + verifyRequestItemTarget( + document, + getDisplayedRequests(store.getState()), + getSortedRequests(store.getState())[1], + "POST", + SIMPLE_SJS + "?foo=bar&baz=42&type=multipart", + { + status: 200, + statusText: "Och Aye", + type: "plain", + fullMimeType: "text/plain; charset=utf-8", + size: L10N.getFormatStrWithNumbers("networkMenu.sizeB", 12), + time: true, + } + ); + + // Wait for raw data toggle to be displayed + const wait = waitForDOM( + document, + "#request-panel .raw-data-toggle-input .devtools-checkbox-toggle" + ); + EventUtils.sendMouseEvent( + { type: "mousedown" }, + document.querySelectorAll(".request-list-item")[0] + ); + clickOnSidebarTab(document, "request"); + await wait; + await testParamsTab("urlencoded"); + + // Wait for header and CodeMirror editor to be displayed + const waitForHeader = waitForDOM(document, "#request-panel .data-header"); + const waitForSourceEditor = waitForDOM( + document, + "#request-panel .CodeMirror-code" + ); + EventUtils.sendMouseEvent( + { type: "mousedown" }, + document.querySelectorAll(".request-list-item")[1] + ); + await Promise.all([waitForHeader, waitForSourceEditor]); + await testParamsTab("multipart"); + + return teardown(monitor); + + async function testParamsTab(type) { + const tabpanel = document.querySelector("#request-panel"); + + function checkVisibility(box) { + is( + tabpanel.querySelector(".CodeMirror-code") === null, + !box.includes("editor"), + "The request post data doesn't have the intended visibility." + ); + } + + is( + tabpanel.querySelectorAll(".raw-data-toggle").length, + type == "urlencoded" ? 1 : 0, + "The display of the raw request data toggle must be correct." + ); + is( + tabpanel.querySelectorAll(".empty-notice").length, + 0, + "The empty notice should not be displayed in this tabpanel." + ); + + is( + tabpanel.querySelector(".data-label").textContent, + L10N.getStr( + type == "urlencoded" ? "paramsFormData" : "paramsPostPayload" + ), + "The post section doesn't have the correct title." + ); + + const labels = tabpanel.querySelectorAll("tr .treeLabelCell .treeLabel"); + const values = tabpanel.querySelectorAll("tr .treeValueCell .objectBox"); + + if (type == "urlencoded") { + checkVisibility("request"); + is( + labels.length, + 2, + "There should be 2 param values displayed in this tabpanel." + ); + is( + labels[0].textContent, + "foo", + "The first post param name was incorrect." + ); + is( + values[0].textContent, + `"bar"`, + "The first post param value was incorrect." + ); + is( + labels[1].textContent, + "baz", + "The second post param name was incorrect." + ); + is( + values[1].textContent, + `"123"`, + "The second post param value was incorrect." + ); + } else { + checkVisibility("request editor"); + + const text = getCodeMirrorValue(monitor); + + ok( + text.includes('Content-Disposition: form-data; name="text"'), + "The text shown in the source editor is incorrect (1.1)." + ); + ok( + text.includes('Content-Disposition: form-data; name="email"'), + "The text shown in the source editor is incorrect (2.1)." + ); + ok( + text.includes('Content-Disposition: form-data; name="range"'), + "The text shown in the source editor is incorrect (3.1)." + ); + ok( + text.includes('Content-Disposition: form-data; name="Custom field"'), + "The text shown in the source editor is incorrect (4.1)." + ); + ok( + text.includes("Some text..."), + "The text shown in the source editor is incorrect (2.2)." + ); + ok( + text.includes("42"), + "The text shown in the source editor is incorrect (3.2)." + ); + ok( + text.includes("Extra data"), + "The text shown in the source editor is incorrect (4.2)." + ); + } + } +}); -- cgit v1.2.3