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 --- .../test/browser_net_streaming-response.js | 89 ++++++++++++++++++++++ 1 file changed, 89 insertions(+) create mode 100644 devtools/client/netmonitor/test/browser_net_streaming-response.js (limited to 'devtools/client/netmonitor/test/browser_net_streaming-response.js') diff --git a/devtools/client/netmonitor/test/browser_net_streaming-response.js b/devtools/client/netmonitor/test/browser_net_streaming-response.js new file mode 100644 index 0000000000..854c496ca4 --- /dev/null +++ b/devtools/client/netmonitor/test/browser_net_streaming-response.js @@ -0,0 +1,89 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +/** + * Tests if reponses from streaming content types (MPEG-DASH, HLS) are + * displayed as XML or plain text + */ + +add_task(async function () { + const { tab, monitor } = await initNetMonitor(CUSTOM_GET_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)); + + const REQUESTS = [ + ["hls-m3u8", /^#EXTM3U/], + ["mpeg-dash", /^<\?xml/], + ]; + + let wait = waitForNetworkEvents(monitor, REQUESTS.length); + for (const [fmt] of REQUESTS) { + const url = CONTENT_TYPE_SJS + "?fmt=" + fmt; + await SpecialPowers.spawn( + tab.linkedBrowser, + [{ url }], + async function (args) { + content.wrappedJSObject.performRequests(1, args.url); + } + ); + } + await wait; + + 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"); + } + + REQUESTS.forEach(([fmt], i) => { + verifyRequestItemTarget( + document, + getDisplayedRequests(store.getState()), + getSortedRequests(store.getState())[i], + "GET", + CONTENT_TYPE_SJS + "?fmt=" + fmt, + { + status: 200, + statusText: "OK", + } + ); + }); + + wait = waitForDOM(document, "#response-panel"); + store.dispatch(Actions.toggleNetworkDetails()); + clickOnSidebarTab(document, "response"); + await wait; + + store.dispatch(Actions.selectRequest(null)); + + await selectIndexAndWaitForSourceEditor(monitor, 0); + // the hls-m3u8 part + testEditorContent(REQUESTS[0]); + + await selectIndexAndWaitForSourceEditor(monitor, 1); + // the mpeg-dash part + testEditorContent(REQUESTS[1]); + + return teardown(monitor); + + function testEditorContent([fmt, textRe]) { + ok( + getCodeMirrorValue(monitor).match(textRe), + "The text shown in the source editor for " + fmt + " is correct." + ); + } +}); -- cgit v1.2.3