summaryrefslogtreecommitdiffstats
path: root/toolkit/components/aboutmemory/tests/test_dumpGCAndCCLogsToFile.xhtml
blob: 9f3cdfe7743121461cb4bb2515c5b35437d2648f (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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
<?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"?>
<window title="GC/CC logging with child processes"
  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">
  </body>

  <!-- test code goes here -->
  <script type="application/javascript"><![CDATA[

  SimpleTest.waitForExplicitFinish();

  let numRemotes = 3;
  let numReady = 0;

  // Create some remote processes, and set up message-passing so that
  // we know when each child is fully initialized.
  let remotes = [];
  SpecialPowers.pushPrefEnv({"set": [["dom.ipc.processCount", numRemotes]]}).then(function() {
    for (let i = 0; i < numRemotes; i++) {
      let w = remotes[i] = window.browsingContext.topChromeWindow.open("remote.xhtml", "", "chrome");

      w.addEventListener("load", function loadHandler() {
        let remoteBrowser = w.document.getElementById("remote");
        let mm = remoteBrowser.messageManager;
        mm.addMessageListener("test:ready", function readyHandler() {
          mm.removeMessageListener("test:ready", readyHandler);
          numReady++;
          if (numReady == numRemotes) {
            // All the remote processes are ready.  Run test.
            runTest();
          }
        });
        mm.loadFrameScript("data:," + encodeURI("sendAsyncMessage('test:ready');"), true);
      }, {once: true});
    }
  });

  let dumper = Cc["@mozilla.org/memory-info-dumper;1"].
               getService(Ci.nsIMemoryInfoDumper);

  function runTest() {
    let numParents = 0;
    let numChildren = 0;
    dumper.dumpGCAndCCLogsToFile(
      /* identifier: */ "test." + Date.now(),
      /* allTraces: */ false,
      /* childProcesses: */ true,
      {
        onDump(gcLog, ccLog, isParent) {
          if (isParent) {
            numParents++;
          } else {
            numChildren++;
          }
          checkAndRemoveLog(gcLog);
          checkAndRemoveLog(ccLog);
        },
        onFinish() {
          is(numParents, 1, "GC/CC logs for the parent process");
          is(numChildren, numRemotes, "GC/CC logs for each child process");
          cleanUpAndFinish();
        },
      }
    );
  }

  function cleanUpAndFinish() {
      // Close the remote processes.
      for (let i = 0; i < numRemotes; i++) {
          remotes[i].close();
      }
      SimpleTest.finish();
  }

  function checkAndRemoveLog(logFile) {
      let name = logFile.path;
      ok(logFile.exists(), "log file "+name+" exists");
      ok(logFile.isFile(), "log file "+name+" is a regular file");
      ok(logFile.fileSize > 0, "log file "+name+" is not empty");
      logFile.remove(/* recursive: */ false);
  }

  ]]></script>
</window>