diff options
Diffstat (limited to 'devtools/client/netmonitor/test/browser_net_fonts.js')
-rw-r--r-- | devtools/client/netmonitor/test/browser_net_fonts.js | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/devtools/client/netmonitor/test/browser_net_fonts.js b/devtools/client/netmonitor/test/browser_net_fonts.js new file mode 100644 index 0000000000..6667ca7962 --- /dev/null +++ b/devtools/client/netmonitor/test/browser_net_fonts.js @@ -0,0 +1,84 @@ +/* Any copyright is dedicated to the Public Domain. + http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +/** + * Tests if font preview is generated correctly + */ + +add_task(async function () { + const { monitor } = await initNetMonitor(FONTS_URL + "?name=fonts", { + 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)); + + // Reload the page to get the font request + const waitForRequests = waitForNetworkEvents(monitor, 3); + await reloadBrowser(); + await waitForRequests; + + const wait = waitForDOMIfNeeded( + document, + "#response-panel .response-font[src^='data:']" + ); + + const requests = document.querySelectorAll( + ".request-list-item .requests-list-status" + ); + + // Check first font request + clickElement(requests[1], monitor); + clickOnSidebarTab(document, "response"); + + await wait; + + ok(true, "Font preview is shown"); + + const tabpanel = document.querySelector("#response-panel"); + let image = tabpanel.querySelector(".response-font"); + await once(image, "load"); + + ok( + image.complete && image.naturalHeight !== 0, + "Font preview got generated correctly" + ); + + let fontData = document.querySelectorAll(".tabpanel-summary-value"); + is(fontData[0].textContent, "Ostrich Sans Medium", "Font name is correct"); + // "font/ttf" is returned on Linux, which is the expected MIME type, though + // "application/octet-stream" is also accepted which is returned on Windows and MacOS. + ok( + ["font/ttf", "application/octet-stream"].includes(fontData[1].textContent), + "MIME type is correct" + ); + + // Check second font request + clickElement(requests[2], monitor); + + await waitForDOM(document, "#response-panel .response-font[src^='data:']"); + + image = tabpanel.querySelector(".response-font"); + await once(image, "load"); + + ok( + image.complete && image.naturalHeight !== 0, + "Font preview got generated correctly" + ); + + fontData = document.querySelectorAll(".tabpanel-summary-value"); + is(fontData[0].textContent, "Ostrich Sans Black", "Font name is correct"); + // Actually expected is "font/ttf", though "application/octet-stream" is + // ok as well and obviously returned when running the test locally. + ok( + ["font/ttf", "application/octet-stream"].includes(fontData[1].textContent), + "MIME type is correct" + ); + + await teardown(monitor); +}); |