File: test_WorkerDebugger_console.xhtml

package info (click to toggle)
thunderbird 1%3A143.0.1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 4,703,968 kB
  • sloc: cpp: 7,770,492; javascript: 5,943,842; ansic: 3,918,754; python: 1,418,263; xml: 653,354; asm: 474,045; java: 183,079; sh: 111,238; makefile: 20,410; perl: 14,359; objc: 13,059; yacc: 4,583; pascal: 3,405; lex: 1,720; ruby: 999; exp: 762; sql: 715; awk: 580; php: 436; lisp: 430; sed: 69; csh: 10
file content (98 lines) | stat: -rw-r--r-- 3,167 bytes parent folder | download | duplicates (14)
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
<?xml version="1.0"?>
<!--
  Any copyright is dedicated to the Public Domain.
  http://creativecommons.org/publicdomain/zero/1.0/
-->
<window title="Test for WorkerDebuggerGlobalScope.console methods"
        xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
        onload="test();">

  <script src="chrome://mochikit/content/tests/SimpleTest/SimpleTest.js"/>
  <script src="chrome://mochikit/content/tests/SimpleTest/EventUtils.js"/>
  <script type="application/javascript" src="dom_worker_helper.js"/>

  <script type="application/javascript">
  <![CDATA[

    const WORKER_URL = "WorkerDebugger.console_worker.js";
    const CHILD_WORKER_URL = "WorkerDebugger.console_childWorker.js";
    const DEBUGGER_URL = BASE_URL + "WorkerDebugger.console_debugger.js";

    consoleMessagesReceived = 0;
    function test() {
      const ConsoleAPIStorage = SpecialPowers.Cc[
        "@mozilla.org/consoleAPI-storage;1"
      ].getService(SpecialPowers.Ci.nsIConsoleAPIStorage);

      function consoleListener() {
        this.observe = this.observe.bind(this);
        ConsoleAPIStorage.addLogEventListener(this.observe, SpecialPowers.wrap(document).nodePrincipal);
      }

      consoleListener.prototype  = {
        observe(aSubject) {
          var obj = aSubject.wrappedJSObject;
          if (obj.arguments[0] == "Hello from the debugger script!" &&
              !consoleMessagesReceived) {
            consoleMessagesReceived++;
            ok(true, "Something has been received");
            ConsoleAPIStorage.removeLogEventListener(this.observe);
          }
        }
      }

      var cl = new consoleListener();

      (async function() {
        SimpleTest.waitForExplicitFinish();

        info("Create a worker that creates a child worker, wait for their " +
             "debuggers to be registered, and initialize them.");
        let promise = waitForMultiple([
          waitForRegister(WORKER_URL, DEBUGGER_URL),
          waitForRegister(CHILD_WORKER_URL, DEBUGGER_URL)
        ]);
        let worker = new Worker(WORKER_URL);
        let [dbg, childDbg] = await promise;

        info("Send a request to the worker debugger. This should cause the " +
             "the worker debugger to send a response.");
        dbg.addListener({
          onMessage(msg) {
            try {
              msg = JSON.parse(msg);
            } catch(e) {
              ok(false, "Something went wrong");
              return;
            }

            if (msg.type == 'finish') {
              ok(consoleMessagesReceived, "We received something via debugger console!");
              dbg.removeListener(this);
              SimpleTest.finish();
              return;
            }

            if (msg.type == 'status') {
              ok(msg.what, msg.msg);
              return;
            }

            ok(false, "Something went wrong");
          }
        });

        dbg.postMessage("do magic");
      })();
    }

  ]]>
  </script>

  <body xmlns="http://www.w3.org/1999/xhtml">
    <p id="display"></p>
    <div id="content" style="display:none;"></div>
    <pre id="test"></pre>
  </body>
  <label id="test-result"/>
</window>