summaryrefslogtreecommitdiffstats
path: root/dom/base/test/chrome/test_bug429785.xhtml
blob: f4f6b414b44128cdf5b0cff126f1a8f8622989ca (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<?xml version="1.0"?>
<?xml-stylesheet href="chrome://global/skin" type="text/css"?>
<?xml-stylesheet href="chrome://mochikit/content/tests/SimpleTest/test.css" type="text/css"?>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=429785
-->
<window title="Mozilla Bug 429785"
  xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
  <script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"/>

  <!-- test results are displayed in the html:body -->
  <body xmlns="http://www.w3.org/1999/xhtml">
  <a href="https://bugzilla.mozilla.org/show_bug.cgi?id=429785"
     target="_blank">Mozilla Bug 429785</a>
  </body>

  <!-- test code goes here -->
  <script type="application/javascript"><![CDATA[
    /** Test for Bug 429785 **/
    SimpleTest.waitForExplicitFinish();
    var errorLogged = false;
    const serv = Cc["@mozilla.org/consoleservice;1"]
                   .getService(Ci.nsIConsoleService);
    var listener = {
      QueryInterface: ChromeUtils.generateQI(["nsIConsoleListener"]),
      observe : function (msg) { errorLogged = true; }
    };

    function step2() {
      is(errorLogged, false, "Should be no errors");

      serv.logStringMessage("This is a test");

      setTimeout(step3, 0);

    }

    function step3() {
      is(errorLogged, true, "Should see errors when they happen");
      serv.unregisterListener(listener);
      SimpleTest.finish();
    }
        
    serv.registerListener(listener);    

    var p = new DOMParser();
    p.parseFromString("<root/>", "application/xml");

    // nsConsoleService notifies its listeners via async proxies, so we need
    // to wait to see whether there was an error reported.
    setTimeout(step2, 0);


  ]]></script>
</window>