File: test_dumpGCAndCCLogsToFile.xhtml

package info (click to toggle)
firefox-esr 128.13.0esr-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 4,230,012 kB
  • sloc: cpp: 7,103,971; javascript: 6,088,450; ansic: 3,653,980; python: 1,212,330; xml: 594,604; asm: 420,652; java: 182,969; sh: 71,124; makefile: 20,747; perl: 13,449; objc: 12,399; yacc: 4,583; cs: 3,846; pascal: 2,973; lex: 1,720; ruby: 1,194; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (90 lines) | stat: -rw-r--r-- 2,967 bytes parent folder | download | duplicates (15)
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>