summaryrefslogtreecommitdiffstats
path: root/devtools/client/netmonitor/test/browser_net_simple-request.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/client/netmonitor/test/browser_net_simple-request.js')
-rw-r--r--devtools/client/netmonitor/test/browser_net_simple-request.js99
1 files changed, 99 insertions, 0 deletions
diff --git a/devtools/client/netmonitor/test/browser_net_simple-request.js b/devtools/client/netmonitor/test/browser_net_simple-request.js
new file mode 100644
index 0000000000..8f5af6f600
--- /dev/null
+++ b/devtools/client/netmonitor/test/browser_net_simple-request.js
@@ -0,0 +1,99 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+"use strict";
+
+/**
+ * Test whether the UI state properly reflects existence of requests
+ * displayed in the Net panel. The following parts of the UI are
+ * tested:
+ * 1) Side panel visibility
+ * 2) Side panel toggle button
+ * 3) Empty user message visibility
+ * 4) Number of requests displayed
+ */
+add_task(async function () {
+ const { monitor } = await initNetMonitor(SIMPLE_URL, {
+ requestCount: 1,
+ });
+ info("Starting test... ");
+
+ const { document, store, windowRequire } = monitor.panelWin;
+ const Actions = windowRequire("devtools/client/netmonitor/src/actions/index");
+
+ store.dispatch(Actions.batchEnable(false));
+
+ ok(
+ document.querySelector(".request-list-empty-notice"),
+ "An empty notice should be displayed when the frontend is opened."
+ );
+ is(
+ store.getState().requests.requests.length,
+ 0,
+ "The requests menu should be empty when the frontend is opened."
+ );
+ is(
+ !!document.querySelector(".network-details-bar"),
+ false,
+ "The network details panel should be hidden when the frontend is opened."
+ );
+
+ await reloadAndWait();
+
+ ok(
+ !document.querySelector(".request-list-empty-notice"),
+ "The empty notice should be hidden after the first request."
+ );
+ is(
+ store.getState().requests.requests.length,
+ 1,
+ "The requests menu should not be empty after the first request."
+ );
+ is(
+ !!document.querySelector(".network-details-bar"),
+ false,
+ "The network details panel should still be hidden after the first request."
+ );
+
+ await reloadAndWait();
+
+ ok(
+ !document.querySelector(".request-list-empty-notice"),
+ "The empty notice should be still hidden after a reload."
+ );
+ is(
+ store.getState().requests.requests.length,
+ 1,
+ "The requests menu should not be empty after a reload."
+ );
+ is(
+ !!document.querySelector(".network-details-bar"),
+ false,
+ "The network details panel should still be hidden after a reload."
+ );
+
+ await clearNetworkEvents(monitor);
+
+ ok(
+ document.querySelector(".request-list-empty-notice"),
+ "An empty notice should be displayed again after clear."
+ );
+ is(
+ store.getState().requests.requests.length,
+ 0,
+ "The requests menu should be empty after clear."
+ );
+ is(
+ !!document.querySelector(".network-details-bar"),
+ false,
+ "The network details panel should still be hidden after clear."
+ );
+
+ return teardown(monitor);
+
+ async function reloadAndWait() {
+ const wait = waitForNetworkEvents(monitor, 1);
+ await reloadBrowser();
+ return wait;
+ }
+});