mirror of
https://gitlab.winehq.org/wine/wine-gecko.git
synced 2024-09-13 09:24:08 -07:00
Backed out changeset 16a75e1c76d0 (bug 986887) for suspicion of causing xpcshell failures.
This commit is contained in:
parent
21d3cae1fe
commit
ec457f44d2
@ -96,23 +96,6 @@ parentLogger.addAppender(new Log.ConsoleAppender(formatter));
|
||||
// Set parent logger (and its children) to
|
||||
// also append to standard out
|
||||
parentLogger.addAppender(new Log.DumpAppender(formatter));
|
||||
// Set parent logger (and its children) to
|
||||
// log to the extensions log file in the profile directory
|
||||
Cu.import("resource://gre/modules/FileUtils.jsm");
|
||||
const KEY_PROFILEDIR = "ProfD";
|
||||
const FILE_EXTENSIONS_LOG = "extensions.log";
|
||||
let logfile = null;
|
||||
let parentFileAppender = null;
|
||||
try {
|
||||
logfile = FileUtils.getFile(KEY_PROFILEDIR, [FILE_EXTENSIONS_LOG]);
|
||||
parentFileAppender = new Log.FileAppender(logfile.path, formatter);
|
||||
parentLogger.addAppender(parentFileAppender);
|
||||
}
|
||||
catch (e) {
|
||||
let message = "Error appending to "+ FILE_EXTENSIONS_LOG +": " + e.message;
|
||||
dump(message + "\n");
|
||||
Services.console.logStringMessage(message);
|
||||
}
|
||||
|
||||
// Create a new logger (child of 'addons' logger)
|
||||
// for use by the Addons Manager
|
||||
@ -889,15 +872,7 @@ var AddonManagerInternal = {
|
||||
delete this.startupChanges[type];
|
||||
gStarted = false;
|
||||
gStartupComplete = false;
|
||||
})
|
||||
.then(() => {
|
||||
if (parentFileAppender !== null) {
|
||||
return parentFileAppender.reset();
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
})
|
||||
.then(null, err => logger.error("Failure during FileAppender log file closure", err));
|
||||
});
|
||||
return shuttingDown;
|
||||
},
|
||||
|
||||
|
180
toolkit/mozapps/extensions/internal/AddonLogging.jsm
Normal file
180
toolkit/mozapps/extensions/internal/AddonLogging.jsm
Normal file
@ -0,0 +1,180 @@
|
||||
/* 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/. */
|
||||
|
||||
"use strict";
|
||||
|
||||
const Cc = Components.classes;
|
||||
const Ci = Components.interfaces;
|
||||
const Cr = Components.results;
|
||||
|
||||
const KEY_PROFILEDIR = "ProfD";
|
||||
const FILE_EXTENSIONS_LOG = "extensions.log";
|
||||
const PREF_LOGGING_ENABLED = "extensions.logging.enabled";
|
||||
|
||||
const LOGGER_FILE_PERM = parseInt("666", 8);
|
||||
|
||||
const NS_PREFBRANCH_PREFCHANGE_TOPIC_ID = "nsPref:changed";
|
||||
|
||||
Components.utils.import("resource://gre/modules/FileUtils.jsm");
|
||||
Components.utils.import("resource://gre/modules/Services.jsm");
|
||||
|
||||
this.EXPORTED_SYMBOLS = [ "LogManager" ];
|
||||
|
||||
var gDebugLogEnabled = false;
|
||||
|
||||
function formatLogMessage(aType, aName, aStr, aException) {
|
||||
let message = aType.toUpperCase() + " " + aName + ": " + aStr;
|
||||
if (aException) {
|
||||
if (typeof aException == "number")
|
||||
return message + ": " + Components.Exception("", aException).name;
|
||||
|
||||
message = message + ": " + aException;
|
||||
// instanceOf doesn't work here, let's duck type
|
||||
if (aException.fileName)
|
||||
message = message + " (" + aException.fileName + ":" + aException.lineNumber + ")";
|
||||
|
||||
if (aException.message == "too much recursion")
|
||||
dump(message + "\n" + aException.stack + "\n");
|
||||
}
|
||||
return message;
|
||||
}
|
||||
|
||||
function getStackDetails(aException) {
|
||||
// Defensively wrap all this to ensure that failing to get the message source
|
||||
// doesn't stop the message from being logged
|
||||
try {
|
||||
if (aException) {
|
||||
if (aException instanceof Ci.nsIException) {
|
||||
return {
|
||||
sourceName: aException.filename,
|
||||
lineNumber: aException.lineNumber
|
||||
};
|
||||
}
|
||||
|
||||
if (typeof aException == "object") {
|
||||
return {
|
||||
sourceName: aException.fileName,
|
||||
lineNumber: aException.lineNumber
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
let stackFrame = Components.stack.caller.caller.caller;
|
||||
return {
|
||||
sourceName: stackFrame.filename,
|
||||
lineNumber: stackFrame.lineNumber
|
||||
};
|
||||
}
|
||||
catch (e) {
|
||||
return {
|
||||
sourceName: null,
|
||||
lineNumber: 0
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
function AddonLogger(aName) {
|
||||
this.name = aName;
|
||||
}
|
||||
|
||||
AddonLogger.prototype = {
|
||||
name: null,
|
||||
|
||||
error: function AddonLogger_error(aStr, aException) {
|
||||
let message = formatLogMessage("error", this.name, aStr, aException);
|
||||
|
||||
let stack = getStackDetails(aException);
|
||||
|
||||
let consoleMessage = Cc["@mozilla.org/scripterror;1"].
|
||||
createInstance(Ci.nsIScriptError);
|
||||
consoleMessage.init(message, stack.sourceName, null, stack.lineNumber, 0,
|
||||
Ci.nsIScriptError.errorFlag, "component javascript");
|
||||
Services.console.logMessage(consoleMessage);
|
||||
|
||||
// Always dump errors, in case the Console Service isn't listening yet
|
||||
dump("*** " + message + "\n");
|
||||
|
||||
try {
|
||||
var tstamp = new Date();
|
||||
var logfile = FileUtils.getFile(KEY_PROFILEDIR, [FILE_EXTENSIONS_LOG]);
|
||||
var stream = Cc["@mozilla.org/network/file-output-stream;1"].
|
||||
createInstance(Ci.nsIFileOutputStream);
|
||||
stream.init(logfile, 0x02 | 0x08 | 0x10, LOGGER_FILE_PERM, 0); // write, create, append
|
||||
var writer = Cc["@mozilla.org/intl/converter-output-stream;1"].
|
||||
createInstance(Ci.nsIConverterOutputStream);
|
||||
writer.init(stream, "UTF-8", 0, 0x0000);
|
||||
writer.writeString(tstamp.toLocaleFormat("%Y-%m-%d %H:%M:%S ") +
|
||||
message + " at " + stack.sourceName + ":" +
|
||||
stack.lineNumber + "\n");
|
||||
writer.close();
|
||||
}
|
||||
catch (e) { }
|
||||
},
|
||||
|
||||
warn: function AddonLogger_warn(aStr, aException) {
|
||||
let message = formatLogMessage("warn", this.name, aStr, aException);
|
||||
|
||||
let stack = getStackDetails(aException);
|
||||
|
||||
let consoleMessage = Cc["@mozilla.org/scripterror;1"].
|
||||
createInstance(Ci.nsIScriptError);
|
||||
consoleMessage.init(message, stack.sourceName, null, stack.lineNumber, 0,
|
||||
Ci.nsIScriptError.warningFlag, "component javascript");
|
||||
Services.console.logMessage(consoleMessage);
|
||||
|
||||
if (gDebugLogEnabled)
|
||||
dump("*** " + message + "\n");
|
||||
},
|
||||
|
||||
log: function AddonLogger_log(aStr, aException) {
|
||||
if (gDebugLogEnabled) {
|
||||
let message = formatLogMessage("log", this.name, aStr, aException);
|
||||
dump("*** " + message + "\n");
|
||||
Services.console.logStringMessage(message);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
this.LogManager = {
|
||||
getLogger: function LogManager_getLogger(aName, aTarget) {
|
||||
let logger = new AddonLogger(aName);
|
||||
|
||||
if (aTarget) {
|
||||
["error", "warn", "log"].forEach(function(name) {
|
||||
let fname = name.toUpperCase();
|
||||
delete aTarget[fname];
|
||||
aTarget[fname] = function LogManager_targetName(aStr, aException) {
|
||||
logger[name](aStr, aException);
|
||||
};
|
||||
});
|
||||
}
|
||||
|
||||
return logger;
|
||||
}
|
||||
};
|
||||
|
||||
var PrefObserver = {
|
||||
init: function PrefObserver_init() {
|
||||
Services.prefs.addObserver(PREF_LOGGING_ENABLED, this, false);
|
||||
Services.obs.addObserver(this, "xpcom-shutdown", false);
|
||||
this.observe(null, NS_PREFBRANCH_PREFCHANGE_TOPIC_ID, PREF_LOGGING_ENABLED);
|
||||
},
|
||||
|
||||
observe: function PrefObserver_observe(aSubject, aTopic, aData) {
|
||||
if (aTopic == "xpcom-shutdown") {
|
||||
Services.prefs.removeObserver(PREF_LOGGING_ENABLED, this);
|
||||
Services.obs.removeObserver(this, "xpcom-shutdown");
|
||||
}
|
||||
else if (aTopic == NS_PREFBRANCH_PREFCHANGE_TOPIC_ID) {
|
||||
try {
|
||||
gDebugLogEnabled = Services.prefs.getBoolPref(PREF_LOGGING_ENABLED);
|
||||
}
|
||||
catch (e) {
|
||||
gDebugLogEnabled = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
PrefObserver.init();
|
@ -7,6 +7,7 @@
|
||||
JS_MODULES_PATH = 'modules/addons'
|
||||
|
||||
EXTRA_JS_MODULES += [
|
||||
'AddonLogging.jsm',
|
||||
'AddonRepository.jsm',
|
||||
'AddonRepository_SQLiteMigrator.jsm',
|
||||
'AddonUpdateChecker.jsm',
|
||||
|
@ -18,10 +18,6 @@ const PREF_GETADDONS_BYIDS_PERFORMANCE = "extensions.getAddons.getWithPerforma
|
||||
// Forcibly end the test if it runs longer than 15 minutes
|
||||
const TIMEOUT_MS = 900000;
|
||||
|
||||
// Get the profile directory for tests to use.
|
||||
// Do this before importing AddonManager.jsm (which logs to profile dir)
|
||||
const gProfD = do_get_profile();
|
||||
|
||||
Components.utils.import("resource://gre/modules/addons/AddonRepository.jsm");
|
||||
Components.utils.import("resource://gre/modules/XPCOMUtils.jsm");
|
||||
Components.utils.import("resource://gre/modules/FileUtils.jsm");
|
||||
@ -1251,6 +1247,9 @@ if ("nsIWindowsRegKey" in AM_Ci) {
|
||||
"@mozilla.org/windows-registry-key;1", WinRegFactory);
|
||||
}
|
||||
|
||||
// Get the profile directory for tests to use.
|
||||
const gProfD = do_get_profile();
|
||||
|
||||
const EXTENSIONS_DB = "extensions.json";
|
||||
let gExtensionsJSON = gProfD.clone();
|
||||
gExtensionsJSON.append(EXTENSIONS_DB);
|
||||
|
Loading…
Reference in New Issue
Block a user