summaryrefslogtreecommitdiffstats
path: root/devtools/platform/tests/xpcshell/test_nsjsinspector.js
blob: a5e63c0cdf69a1ae9ee62004c01a69a169a821a9 (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
56
57
58
59
60
61
62
63
64
65
66
/* Any copyright is dedicated to the Public Domain.
   http://creativecommons.org/publicdomain/zero/1.0/ */

"use strict";

// Test the basic functionality of the nsIJSInspector component.
var gCount = 0;
const MAX = 10;

const { Services } = ChromeUtils.import("resource://gre/modules/Services.jsm");
var inspector = Cc["@mozilla.org/jsinspector;1"].getService(Ci.nsIJSInspector);

// Emulate 10 simultaneously-debugged windows from 3 separate client connections.
var requestor = count => ({
  url: "http://foo/bar/" + count,
  connection: "conn" + (count % 3),
});

function run_test() {
  test_nesting();
}

function test_nesting() {
  Assert.equal(inspector.eventLoopNestLevel, 0);

  Services.tm.dispatchToMainThread({ run: enterEventLoop });

  Assert.equal(inspector.enterNestedEventLoop(requestor(gCount)), 0);
  Assert.equal(inspector.eventLoopNestLevel, 0);
  Assert.equal(inspector.lastNestRequestor, null);
}

function enterEventLoop() {
  if (gCount++ < MAX) {
    Services.tm.dispatchToMainThread({ run: enterEventLoop });

    Object.create(requestor(gCount));

    Assert.equal(inspector.eventLoopNestLevel, gCount);
    Assert.equal(inspector.lastNestRequestor.url, requestor(gCount - 1).url);
    Assert.equal(
      inspector.lastNestRequestor.connection,
      requestor(gCount - 1).connection
    );
    Assert.equal(inspector.enterNestedEventLoop(requestor(gCount)), gCount);
  } else {
    Assert.equal(gCount, MAX + 1);
    Services.tm.dispatchToMainThread({ run: exitEventLoop });
  }
}

function exitEventLoop() {
  if (inspector.lastNestRequestor != null) {
    Assert.equal(inspector.lastNestRequestor.url, requestor(gCount - 1).url);
    Assert.equal(
      inspector.lastNestRequestor.connection,
      requestor(gCount - 1).connection
    );
    if (gCount-- > 1) {
      Services.tm.dispatchToMainThread({ run: exitEventLoop });
    }

    Assert.equal(inspector.exitNestedEventLoop(), gCount);
    Assert.equal(inspector.eventLoopNestLevel, gCount);
  }
}