tools/profiler/tests/test_run.js

Wed, 31 Dec 2014 06:09:35 +0100

author
Michael Schloh von Bennewitz <michael@schloh.com>
date
Wed, 31 Dec 2014 06:09:35 +0100
changeset 0
6474c204b198
permissions
-rw-r--r--

Cloned upstream origin tor-browser at tor-browser-31.3.0esr-4.5-1-build1
revision ID fc1c9ff7c1b2defdbc039f12214767608f46423f for hacking purpose.

michael@0 1 /* This Source Code Form is subject to the terms of the Mozilla Public
michael@0 2 * License, v. 2.0. If a copy of the MPL was not distributed with this
michael@0 3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
michael@0 4
michael@0 5 function run_test() {
michael@0 6 // If we can't get the profiler component then assume gecko was
michael@0 7 // built without it and pass all the tests
michael@0 8 var profilerCc = Cc["@mozilla.org/tools/profiler;1"];
michael@0 9 if (!profilerCc)
michael@0 10 return;
michael@0 11
michael@0 12 var profiler = Cc["@mozilla.org/tools/profiler;1"].getService(Ci.nsIProfiler);
michael@0 13 if (!profiler)
michael@0 14 return;
michael@0 15
michael@0 16 do_check_true(!profiler.IsActive());
michael@0 17
michael@0 18 profiler.StartProfiler(1000, 10, [], 0);
michael@0 19
michael@0 20 do_check_true(profiler.IsActive());
michael@0 21
michael@0 22 do_test_pending();
michael@0 23
michael@0 24 do_timeout(1000, function wait() {
michael@0 25 // Check responsiveness
michael@0 26 var resp = profiler.GetResponsivenessTimes({});
michael@0 27 do_check_true(resp.length > 10);
michael@0 28
michael@0 29 // Check text profile format
michael@0 30 var profileStr = profiler.GetProfile();
michael@0 31 do_check_true(profileStr.length > 10);
michael@0 32
michael@0 33 // check json profile format
michael@0 34 var profileObj = profiler.getProfileData();
michael@0 35 do_check_neq(profileObj, null);
michael@0 36 do_check_neq(profileObj.threads, null);
michael@0 37 do_check_true(profileObj.threads.length >= 1);
michael@0 38 do_check_neq(profileObj.threads[0].samples, null);
michael@0 39 // NOTE: The number of samples will be empty since we
michael@0 40 // don't have any labels in the xpcshell code
michael@0 41
michael@0 42 profiler.StopProfiler();
michael@0 43 do_check_true(!profiler.IsActive());
michael@0 44 do_test_finished();
michael@0 45 });
michael@0 46
michael@0 47
michael@0 48 }

mercurial