diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /toolkit/components/pdfjs/test/browser_pdfjs_editing_telemetry.js | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'toolkit/components/pdfjs/test/browser_pdfjs_editing_telemetry.js')
-rw-r--r-- | toolkit/components/pdfjs/test/browser_pdfjs_editing_telemetry.js | 96 |
1 files changed, 96 insertions, 0 deletions
diff --git a/toolkit/components/pdfjs/test/browser_pdfjs_editing_telemetry.js b/toolkit/components/pdfjs/test/browser_pdfjs_editing_telemetry.js new file mode 100644 index 0000000000..f05b28c917 --- /dev/null +++ b/toolkit/components/pdfjs/test/browser_pdfjs_editing_telemetry.js @@ -0,0 +1,96 @@ +/* Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/publicdomain/zero/1.0/ */ + +const RELATIVE_DIR = "toolkit/components/pdfjs/test/"; +const TESTROOT = "http://example.com/browser/" + RELATIVE_DIR; + +// Test telemetry. +add_task(async function test() { + let mimeService = Cc["@mozilla.org/mime;1"].getService(Ci.nsIMIMEService); + let handlerInfo = mimeService.getFromTypeAndExtension( + "application/pdf", + "pdf" + ); + + // Make sure pdf.js is the default handler. + is( + handlerInfo.alwaysAskBeforeHandling, + false, + "pdf handler defaults to always-ask is false" + ); + is( + handlerInfo.preferredAction, + Ci.nsIHandlerInfo.handleInternally, + "pdf handler defaults to internal" + ); + + info("Pref action: " + handlerInfo.preferredAction); + + await BrowserTestUtils.withNewTab( + { gBrowser, url: "about:blank" }, + async function (browser) { + await SpecialPowers.pushPrefEnv({ + set: [["pdfjs.annotationEditorMode", 0]], + }); + + Services.fog.testResetFOG(); + + // check that PDF is opened with internal viewer + await waitForPdfJSAllLayers(browser, TESTROOT + "file_pdfjs_test.pdf", [ + [ + "annotationEditorLayer", + "annotationLayer", + "textLayer", + "canvasWrapper", + ], + ["annotationEditorLayer", "textLayer", "canvasWrapper"], + ]); + + let spanBox = await getSpanBox(browser, "and found references"); + + await Services.fog.testFlushAllChildren(); + Assert.equal(Glean.pdfjs.editing.freetext.testGetValue() || 0, 0); + + await enableEditor(browser, "FreeText"); + await addFreeText(browser, "hello", spanBox); + + await BrowserTestUtils.waitForCondition( + async () => (await countElements(browser, ".freeTextEditor")) !== 0 + ); + Assert.equal(await countElements(browser, ".freeTextEditor"), 2); + + await Services.fog.testFlushAllChildren(); + + Assert.equal(Glean.pdfjs.editing.freetext.testGetValue(), 2); + + spanBox = await getSpanBox(browser, "forums and ask questions"); + await addFreeText(browser, "world", spanBox); + + await BrowserTestUtils.waitForCondition( + async () => (await countElements(browser, ".freeTextEditor")) !== 1 + ); + Assert.equal(await countElements(browser, ".freeTextEditor"), 3); + + await Services.fog.testFlushAllChildren(); + + Assert.equal(Glean.pdfjs.editing.freetext.testGetValue(), 3); + + Assert.equal(Glean.pdfjs.editing.print.testGetValue() || 0, 0); + document.getElementById("cmd_print").doCommand(); + await BrowserTestUtils.waitForCondition(() => { + let preview = document.querySelector(".printPreviewBrowser"); + return preview && BrowserTestUtils.isVisible(preview); + }); + EventUtils.synthesizeKey("KEY_Escape"); + + await Services.fog.testFlushAllChildren(); + + Assert.equal(Glean.pdfjs.editing.print.testGetValue(), 1); + + await SpecialPowers.spawn(browser, [], async function () { + var viewer = content.wrappedJSObject.PDFViewerApplication; + await viewer.close(); + }); + } + ); +}); |