summaryrefslogtreecommitdiffstats
path: root/tools/profiler/tests/xpcshell/test_run.js
blob: 607c8286776cbcf892d8ec5d0965f27409d8d762 (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
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

function run_test() {
  if (!AppConstants.MOZ_GECKO_PROFILER) {
    return;
  }

  Assert.ok(!Services.profiler.IsActive());

  Services.profiler.StartProfiler(1000, 10, []);

  Assert.ok(Services.profiler.IsActive());

  do_test_pending();

  do_timeout(1000, function wait() {
    // Check text profile format
    var profileStr = Services.profiler.GetProfile();
    Assert.ok(profileStr.length > 10);

    // check json profile format
    var profileObj = Services.profiler.getProfileData();
    Assert.notEqual(profileObj, null);
    Assert.notEqual(profileObj.threads, null);
    // We capture memory counters by default only when jemalloc is turned
    // on (and it isn't for ASAN), so unless we can conditionalize for ASAN
    // here we can't check that we're capturing memory counter data.
    Assert.notEqual(profileObj.counters, null);
    Assert.notEqual(profileObj.memory, null);
    Assert.ok(profileObj.threads.length >= 1);
    Assert.notEqual(profileObj.threads[0].samples, null);
    // NOTE: The number of samples will be empty since we
    //       don't have any labels in the xpcshell code

    Services.profiler.StopProfiler();
    Assert.ok(!Services.profiler.IsActive());
    do_test_finished();
  });
}