xpcom/tests/unit/test_bug656331.js

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/xpcom/tests/unit/test_bug656331.js	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,39 @@
     1.4 +Components.utils.import("resource://gre/modules/XPCOMUtils.jsm");
     1.5 +
     1.6 +const Cc = Components.classes;
     1.7 +const Ci = Components.interfaces;
     1.8 +
     1.9 +function info(s) {
    1.10 +  dump("TEST-INFO | test_bug656331.js | " + s + "\n");
    1.11 +}
    1.12 +
    1.13 +var gMessageExpected = /Native module.*has version 3.*expected/;
    1.14 +var gFound = false;
    1.15 +
    1.16 +const kConsoleListener = {
    1.17 +  QueryInterface: XPCOMUtils.generateQI([Ci.nsIConsoleListener]),
    1.18 +  
    1.19 +  observe: function listener_observe(message) {
    1.20 +    if (gMessageExpected.test(message.message))
    1.21 +      gFound = true;
    1.22 +  }
    1.23 +};
    1.24 +
    1.25 +function run_test() {
    1.26 +  let cs = Components.classes["@mozilla.org/consoleservice;1"].
    1.27 +    getService(Ci.nsIConsoleService);
    1.28 +  cs.registerListener(kConsoleListener);
    1.29 +
    1.30 +  let manifest = do_get_file('bug656331.manifest');
    1.31 +  Components.manager.autoRegister(manifest);
    1.32 +
    1.33 +  do_check_false("{f18fb09b-28b4-4435-bc5b-8027f18df743}" in Components.classesByID);
    1.34 +
    1.35 +  do_test_pending();
    1.36 +  Components.classes["@mozilla.org/thread-manager;1"].
    1.37 +    getService(Ci.nsIThreadManager).mainThread.dispatch(function() {
    1.38 +      cs.unregisterListener(kConsoleListener);
    1.39 +      do_check_true(gFound);
    1.40 +      do_test_finished();
    1.41 +    }, 0);
    1.42 +}

mercurial