summaryrefslogtreecommitdiffstats
path: root/dom/tests/browser/browser_ConsoleAPI_originAttributes.js
diff options
context:
space:
mode:
Diffstat (limited to 'dom/tests/browser/browser_ConsoleAPI_originAttributes.js')
-rw-r--r--dom/tests/browser/browser_ConsoleAPI_originAttributes.js108
1 files changed, 108 insertions, 0 deletions
diff --git a/dom/tests/browser/browser_ConsoleAPI_originAttributes.js b/dom/tests/browser/browser_ConsoleAPI_originAttributes.js
new file mode 100644
index 0000000000..9e96dba728
--- /dev/null
+++ b/dom/tests/browser/browser_ConsoleAPI_originAttributes.js
@@ -0,0 +1,108 @@
+/* Any copyright is dedicated to the Public Domain.
+ http://creativecommons.org/publicdomain/zero/1.0/ */
+
+const ConsoleAPIStorage = Cc["@mozilla.org/consoleAPI-storage;1"].getService(
+ Ci.nsIConsoleAPIStorage
+);
+
+const { WebExtensionPolicy } = Cu.getGlobalForObject(
+ ChromeUtils.importESModule("resource://gre/modules/AppConstants.sys.mjs")
+);
+
+const FAKE_ADDON_ID = "test-webext-addon@mozilla.org";
+const EXPECTED_CONSOLE_ID = `addon/${FAKE_ADDON_ID}`;
+const EXPECTED_CONSOLE_MESSAGE_CONTENT = "fake-webext-addon-test-log-message";
+
+const ConsoleObserver = {
+ init() {
+ ConsoleAPIStorage.addLogEventListener(
+ this.observe,
+ Cc["@mozilla.org/systemprincipal;1"].createInstance(Ci.nsIPrincipal)
+ );
+ },
+
+ uninit() {
+ ConsoleAPIStorage.removeLogEventListener(this.observe);
+ },
+
+ observe(aSubject) {
+ let consoleAPIMessage = aSubject.wrappedJSObject;
+
+ is(
+ consoleAPIMessage.arguments[0],
+ EXPECTED_CONSOLE_MESSAGE_CONTENT,
+ "the consoleAPIMessage contains the expected message"
+ );
+
+ is(
+ consoleAPIMessage.addonId,
+ FAKE_ADDON_ID,
+ "the consoleAPImessage originAttributes contains the expected addonId"
+ );
+
+ let cachedMessages = ConsoleAPIStorage.getEvents().filter(msg => {
+ return msg.addonId == FAKE_ADDON_ID;
+ });
+
+ is(
+ cachedMessages.length,
+ 1,
+ "found the expected cached console messages from the addon"
+ );
+ is(
+ cachedMessages[0] && cachedMessages[0].addonId,
+ FAKE_ADDON_ID,
+ "the cached message originAttributes contains the expected addonId"
+ );
+
+ finish();
+ },
+};
+
+function test() {
+ ConsoleObserver.init();
+
+ waitForExplicitFinish();
+
+ let uuidGenerator = Services.uuid;
+ let uuid = uuidGenerator.generateUUID().number;
+ uuid = uuid.slice(1, -1); // Strip { and } off the UUID.
+
+ const url = `moz-extension://${uuid}/`;
+ let policy = new WebExtensionPolicy({
+ id: FAKE_ADDON_ID,
+ mozExtensionHostname: uuid,
+ baseURL: "file:///",
+ allowedOrigins: new MatchPatternSet([]),
+ localizeCallback() {},
+ });
+ policy.active = true;
+
+ let baseURI = Services.io.newURI(url);
+ let principal = Services.scriptSecurityManager.createContentPrincipal(
+ baseURI,
+ {}
+ );
+
+ let chromeWebNav = Services.appShell.createWindowlessBrowser(true);
+ let docShell = chromeWebNav.docShell;
+ docShell.createAboutBlankContentViewer(principal, principal);
+
+ info("fake webextension docShell created");
+
+ registerCleanupFunction(function () {
+ policy.active = false;
+ if (chromeWebNav) {
+ chromeWebNav.close();
+ chromeWebNav = null;
+ }
+ ConsoleObserver.uninit();
+ });
+
+ let window = docShell.contentViewer.DOMDocument.defaultView;
+ window.eval(`console.log("${EXPECTED_CONSOLE_MESSAGE_CONTENT}");`);
+ chromeWebNav.close();
+ chromeWebNav = null;
+
+ info("fake webextension page logged a console api message");
+}