diff options
Diffstat (limited to 'devtools/client/webconsole/test/browser_webconsole_notifications.js')
-rw-r--r-- | devtools/client/webconsole/test/browser_webconsole_notifications.js | 77 |
1 files changed, 77 insertions, 0 deletions
diff --git a/devtools/client/webconsole/test/browser_webconsole_notifications.js b/devtools/client/webconsole/test/browser_webconsole_notifications.js new file mode 100644 index 000000000..4bda9192f --- /dev/null +++ b/devtools/client/webconsole/test/browser_webconsole_notifications.js @@ -0,0 +1,77 @@ +/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */ +/* vim: set ft=javascript ts=2 et sw=2 tw=80: */ +/* Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/publicdomain/zero/1.0/ */ + +"use strict"; + +const TEST_URI = "data:text/html;charset=utf-8,<p>Web Console test for " + + "notifications"; + +add_task(function* () { + yield loadTab(TEST_URI); + + let consoleOpened = promise.defer(); + let gotEvents = waitForEvents(consoleOpened.promise); + yield openConsole().then(() => { + consoleOpened.resolve(); + }); + + yield gotEvents; +}); + +function waitForEvents(onConsoleOpened) { + let deferred = promise.defer(); + + function webConsoleCreated(id) { + Services.obs.removeObserver(observer, "web-console-created"); + ok(HUDService.getHudReferenceById(id), "We have a hud reference"); + content.wrappedJSObject.console.log("adding a log message"); + } + + function webConsoleDestroyed(id) { + Services.obs.removeObserver(observer, "web-console-destroyed"); + ok(!HUDService.getHudReferenceById(id), "We do not have a hud reference"); + executeSoon(deferred.resolve); + } + + function webConsoleMessage(id, nodeID) { + Services.obs.removeObserver(observer, "web-console-message-created"); + ok(id, "we have a console ID"); + is(typeof nodeID, "string", "message node id is a string"); + onConsoleOpened.then(closeConsole); + } + + let observer = { + + QueryInterface: XPCOMUtils.generateQI([Ci.nsIObserver]), + + observe: function observe(subject, topic, data) { + subject = subject.QueryInterface(Ci.nsISupportsString); + + switch (topic) { + case "web-console-created": + webConsoleCreated(subject.data); + break; + case "web-console-destroyed": + webConsoleDestroyed(subject.data); + break; + case "web-console-message-created": + webConsoleMessage(subject, data); + break; + default: + break; + } + }, + + init: function init() { + Services.obs.addObserver(this, "web-console-created", false); + Services.obs.addObserver(this, "web-console-destroyed", false); + Services.obs.addObserver(this, "web-console-message-created", false); + } + }; + + observer.init(); + + return deferred.promise; +} |