diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-07 19:33:14 +0000 |
commit | 36d22d82aa202bb199967e9512281e9a53db42c9 (patch) | |
tree | 105e8c98ddea1c1e4784a60a5a6410fa416be2de /devtools/client/netmonitor/test/browser_net_status-bar.js | |
parent | Initial commit. (diff) | |
download | firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip |
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'devtools/client/netmonitor/test/browser_net_status-bar.js')
-rw-r--r-- | devtools/client/netmonitor/test/browser_net_status-bar.js | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/devtools/client/netmonitor/test/browser_net_status-bar.js b/devtools/client/netmonitor/test/browser_net_status-bar.js new file mode 100644 index 0000000000..3ca8ac2da6 --- /dev/null +++ b/devtools/client/netmonitor/test/browser_net_status-bar.js @@ -0,0 +1,60 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +/** + * Test whether the StatusBar properly renders expected labels. + */ +add_task(async () => { + 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)); + + await SpecialPowers.pushPrefEnv({ + set: [["privacy.reduceTimerPrecision", false]], + }); + + const requestsDone = waitForNetworkEvents(monitor, 1); + const markersDone = waitForTimelineMarkers(monitor); + await reloadBrowser(); + await Promise.all([requestsDone, markersDone]); + + const statusBar = document.querySelector(".devtools-toolbar-bottom"); + const requestCount = statusBar.querySelector( + ".requests-list-network-summary-count" + ); + const size = statusBar.querySelector( + ".requests-list-network-summary-transfer" + ); + const onContentLoad = statusBar.querySelector(".dom-content-loaded"); + const onLoad = statusBar.querySelector(".load"); + + // All expected labels should be there + ok(requestCount, "There must be request count label"); + ok(size, "There must be size label"); + ok(onContentLoad, "There must be DOMContentLoaded label"); + ok(onLoad, "There must be load label"); + + // The content should not be empty. The UI update can also be async, + // so use waitUntil. + await waitUntil(() => requestCount.textContent); + ok(true, "There must be request count label text"); + + await waitUntil(() => size.textContent); + ok(true, "There must be size label text"); + + await waitUntil(() => onContentLoad.textContent); + ok(true, "There must be DOMContentLoaded label text"); + + await waitUntil(() => onLoad.textContent); + ok(true, "There must be load label text"); + + return teardown(monitor); +}); |