summaryrefslogtreecommitdiffstats
path: root/devtools/client/netmonitor/test/browser_net_edit_resend_cancel.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/client/netmonitor/test/browser_net_edit_resend_cancel.js')
-rw-r--r--devtools/client/netmonitor/test/browser_net_edit_resend_cancel.js68
1 files changed, 68 insertions, 0 deletions
diff --git a/devtools/client/netmonitor/test/browser_net_edit_resend_cancel.js b/devtools/client/netmonitor/test/browser_net_edit_resend_cancel.js
new file mode 100644
index 0000000000..e0958c3497
--- /dev/null
+++ b/devtools/client/netmonitor/test/browser_net_edit_resend_cancel.js
@@ -0,0 +1,68 @@
+/* Any copyright is dedicated to the Public Domain.
+ * http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"use strict";
+
+/**
+ * Tests if original request's header panel is visible when custom request is cancelled.
+ */
+
+add_task(async function () {
+ if (
+ Services.prefs.getBoolPref(
+ "devtools.netmonitor.features.newEditAndResend",
+ true
+ )
+ ) {
+ ok(
+ true,
+ "Skip this test when pref is true, because this panel won't be default when that is the case."
+ );
+ return;
+ }
+
+ const { monitor } = await initNetMonitor(HTTPS_SIMPLE_URL, {
+ requestCount: 1,
+ });
+ info("Starting test... ");
+
+ const { document, store, windowRequire } = monitor.panelWin;
+ const { getSelectedRequest } = windowRequire(
+ "devtools/client/netmonitor/src/selectors/index"
+ );
+ const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
+ store.dispatch(Actions.batchEnable(false));
+
+ // Reload to have one request in the list
+ const waitForEvents = waitForNetworkEvents(monitor, 1);
+ await navigateTo(HTTPS_SIMPLE_URL);
+ await waitForEvents;
+
+ // Context Menu > "Edit & Resend"
+ const firstRequest = document.querySelectorAll(".request-list-item")[0];
+ const waitForHeaders = waitUntil(() =>
+ document.querySelector(".headers-overview")
+ );
+ EventUtils.sendMouseEvent({ type: "mousedown" }, firstRequest);
+ await waitForHeaders;
+ EventUtils.sendMouseEvent({ type: "contextmenu" }, firstRequest);
+ const firstRequestState = getSelectedRequest(store.getState());
+ await selectContextMenuItem(monitor, "request-list-context-edit-resend");
+
+ // Waits for "Edit & Resend" panel to appear > New request "Cancel"
+ await waitUntil(() => document.querySelector(".custom-request-panel"));
+ document.querySelector("#custom-request-close-button").click();
+ const finalRequestState = getSelectedRequest(store.getState());
+
+ ok(
+ firstRequestState.id === finalRequestState.id,
+ "Original request is selected after cancel button is clicked"
+ );
+
+ ok(
+ document.querySelector(".headers-overview") !== null,
+ "Request is selected and headers panel is visible"
+ );
+
+ await teardown(monitor);
+});