diff options
Diffstat (limited to 'comm/mail/base/test/webextensions/browser_permissions_optional.js')
-rw-r--r-- | comm/mail/base/test/webextensions/browser_permissions_optional.js | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/comm/mail/base/test/webextensions/browser_permissions_optional.js b/comm/mail/base/test/webextensions/browser_permissions_optional.js new file mode 100644 index 0000000000..750658a8fd --- /dev/null +++ b/comm/mail/base/test/webextensions/browser_permissions_optional.js @@ -0,0 +1,53 @@ +"use strict"; +add_task(async function test_request_permissions_without_prompt() { + async function pageScript() { + const NO_PROMPT_PERM = "activeTab"; + window.addEventListener( + "keypress", + async () => { + let permGranted = await browser.permissions.request({ + permissions: [NO_PROMPT_PERM], + }); + browser.test.assertTrue( + permGranted, + `${NO_PROMPT_PERM} permission was granted.` + ); + let perms = await browser.permissions.getAll(); + browser.test.assertTrue( + perms.permissions.includes(NO_PROMPT_PERM), + `${NO_PROMPT_PERM} permission exists.` + ); + browser.test.sendMessage("permsGranted"); + }, + { once: true } + ); + browser.test.sendMessage("pageReady"); + } + + let extension = ExtensionTestUtils.loadExtension({ + background() { + browser.test.sendMessage("ready", browser.runtime.getURL("page.html")); + }, + files: { + "page.html": `<html><head><script src="page.js"></script></head></html>`, + "page.js": pageScript, + }, + manifest: { + optional_permissions: ["activeTab"], + }, + }); + await extension.startup(); + + let url = await extension.awaitMessage("ready"); + + let tab = openContentTab(url, undefined, null); + await extension.awaitMessage("pageReady"); + await new Promise(resolve => requestAnimationFrame(resolve)); + await BrowserTestUtils.synthesizeMouseAtCenter(tab.browser, {}, tab.browser); + await BrowserTestUtils.synthesizeKey("a", {}, tab.browser); + await extension.awaitMessage("permsGranted"); + await extension.unload(); + + let tabmail = document.getElementById("tabmail"); + tabmail.closeTab(tab); +}); |