70 lines
2.4 KiB
HTML
70 lines
2.4 KiB
HTML
<!-- 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/. -->
|
|
<html>
|
|
<meta charset="utf-8">
|
|
<!-- Pick off begin time as a cgi argument and print it out -->
|
|
<!-- call this with an arg, e.g. file://foo/startup-test.html?begin=12345678 -->
|
|
<!-- In-line this to avoid compilation. -->
|
|
<script language="Javascript" type="text/javascript" src="chrome://talos-powers-content/content/TalosPowersContent.js"></script>
|
|
<script language="Javascript" type="text/javascript" src="../scripts/MozillaFileLogger.js"></script>
|
|
<script language="Javascript" type="text/javascript" src="../scripts/Profiler.js"></script>
|
|
<script language="JavaScript" type="text/javascript" src="../tests/quit.js"></script>
|
|
<script language="javascript" type="text/javascript">
|
|
|
|
function painted() {
|
|
Profiler.pause();
|
|
Profiler.initFromURLQueryParams(location.search);
|
|
Profiler.finishStartupProfiling();
|
|
|
|
window.removeEventListener("MozAfterPaint", painted, true);
|
|
|
|
TalosPowersContent.getStartupInfo().then(function(startupInfo) {
|
|
let startupTime = startupInfo['firstPaint'] - startupInfo['process'];
|
|
|
|
document.body.textContent = 'Startup time = ' + startupTime + ' ms';
|
|
if (window.dump) {
|
|
dumpLog('__start_report' + startupTime + '__end_report\n\n');
|
|
}
|
|
dumpConsoleAndQuit();
|
|
});
|
|
}
|
|
|
|
function failed() {
|
|
if (window.dump) {
|
|
dumpLog('BROWSER FAILED TO GENERATE MOZAFTERPAINT IN 5 SECONDS');
|
|
}
|
|
dumpConsoleAndQuit();
|
|
}
|
|
|
|
function dumpConsoleAndQuit() {
|
|
var messages = {}
|
|
|
|
try {
|
|
netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
|
|
var consoleService = Components.classes['@mozilla.org/consoleservice;1'].getService(Components.interfaces.nsIConsoleService);
|
|
consoleService.getMessageArray(messages, {});
|
|
} catch(ex) {
|
|
dumpLog(ex + '\n');
|
|
}
|
|
|
|
for (var i = 0; i < messages.value.length; i++)
|
|
dumpLog(messages.value[i].message + '\n');
|
|
|
|
// Close window asynchronously, there might still be startup operations that still need to run
|
|
window.setTimeout(function() {
|
|
if (window.dump) {
|
|
dumpLog('__startTimestamp' + Date.now() + '__endTimestamp\n');
|
|
}
|
|
goQuitApplication();
|
|
window.close();
|
|
}, 0);
|
|
}
|
|
|
|
window.addEventListener("MozAfterPaint", painted, true);
|
|
setTimeout(failed, 5000);
|
|
|
|
</script>
|
|
<body></body>
|
|
</html>
|