Bug 891324 - Make nsIXULRuntime accessible using Services.appinfo in xpcshell tests. r=gavin

This commit is contained in:
Paolo Amadini 2013-07-20 15:15:03 +02:00
parent 033b09aa7a
commit f64dd71db0
6 changed files with 121 additions and 66 deletions

View File

@ -34,10 +34,10 @@ add_task(function test_getSystemDownloadsDirectory()
let downloadDir;
// OSX / Linux / Windows but not XP/2k
if (("nsILocalFileMac" in Ci) ||
("@mozilla.org/gnome-gconf-service;1" in Cc) ||
("@mozilla.org/windows-registry-key;1" in Cc &&
parseFloat(Services.sysinfo.getProperty("version")) >= 6)) {
if (Services.appinfo.OS == "Darwin" ||
Services.appinfo.OS == "Linux" ||
(Services.appinfo.OS == "WINNT" &&
parseFloat(Services.sysinfo.getProperty("version")) >= 6)) {
downloadDir = yield DownloadIntegration.getSystemDownloadsDirectory();
do_check_true(downloadDir instanceof Ci.nsIFile);
do_check_eq(downloadDir.path, tempDir.path);

View File

@ -6,6 +6,7 @@ this.EXPORTED_SYMBOLS = ["Services"];
const Ci = Components.interfaces;
const Cc = Components.classes;
const Cr = Components.results;
Components.utils.import("resource://gre/modules/XPCOMUtils.jsm");
@ -18,9 +19,15 @@ XPCOMUtils.defineLazyGetter(Services, "prefs", function () {
});
XPCOMUtils.defineLazyGetter(Services, "appinfo", function () {
return Cc["@mozilla.org/xre/app-info;1"]
.getService(Ci.nsIXULAppInfo)
.QueryInterface(Ci.nsIXULRuntime);
let appinfo = Cc["@mozilla.org/xre/app-info;1"]
.getService(Ci.nsIXULRuntime);
try {
appinfo.QueryInterface(Ci.nsIXULAppInfo);
} catch (ex if ex instanceof Components.Exception &&
ex.result == Cr.NS_NOINTERFACE) {
// Not all applications implement nsIXULAppInfo (e.g. xpcshell doesn't).
}
return appinfo;
});
XPCOMUtils.defineLazyGetter(Services, "dirsvc", function () {

View File

@ -16,7 +16,6 @@ MOCHITEST_BROWSER_FILES = \
browser_Deprecated.js \
browser_Geometry.js \
browser_InlineSpellChecker.js \
browser_Services.js \
browser_Troubleshoot.js \
$(NULL)

View File

@ -1,58 +0,0 @@
/* 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 test() {
/** Tests for Services.jsm (Bug 512784) **/
ok(Services, "Services object exists");
checkServices();
}
function checkService(service, interface) {
ok(service in Services, "Services." + service + " exists");
ok(Services[service] instanceof interface, "Services." + service + " is an " + interface);
}
function checkServices() {
checkService("prefs", Ci.nsIPrefBranch);
checkService("prefs", Ci.nsIPrefService);
checkService("contentPrefs", Ci.nsIContentPrefService);
checkService("wm", Ci.nsIWindowMediator);
checkService("obs", Ci.nsIObserverService);
checkService("perms", Ci.nsIPermissionManager);
checkService("io", Ci.nsIIOService);
checkService("io", Ci.nsIIOService2);
checkService("appinfo", Ci.nsIXULAppInfo);
checkService("appinfo", Ci.nsIXULRuntime);
checkService("dirsvc", Ci.nsIDirectoryService);
checkService("dirsvc", Ci.nsIProperties);
checkService("prompt", Ci.nsIPromptService);
if ("nsIBrowserSearchService" in Ci)
checkService("search", Ci.nsIBrowserSearchService);
checkService("storage", Ci.mozIStorageService);
checkService("vc", Ci.nsIVersionComparator);
checkService("locale", Ci.nsILocaleService);
checkService("scriptloader", Ci.mozIJSSubScriptLoader);
checkService("ww", Ci.nsIWindowWatcher);
checkService("tm", Ci.nsIThreadManager);
checkService("droppedLinkHandler", Ci.nsIDroppedLinkHandler);
checkService("strings", Ci.nsIStringBundleService);
checkService("urlFormatter", Ci.nsIURLFormatter);
checkService("eTLD", Ci.nsIEffectiveTLDService);
checkService("cookies", Ci.nsICookieManager2);
checkService("logins", Ci.nsILoginManager);
checkService("telemetry", Ci.nsITelemetry);
checkService("sysinfo", Ci.nsIPropertyBag2);
checkService("clipboard", Ci.nsIClipboard);
checkService("console", Ci.nsIConsoleService);
checkService("startup", Ci.nsIAppStartup);
checkService("appShell", Ci.nsIAppShellService);
checkService("cache", Ci.nsICacheService);
checkService("scriptSecurityManager", Ci.nsIScriptSecurityManager);
checkService("domStorageManager", Ci.nsIDOMStorageManager);
checkService("DOMRequest", Ci.nsIDOMRequestService);
checkService("downloads", Ci.nsIDownloadManager);
checkService("focus", Ci.nsIFocusManager);
checkService("uriFixup", Ci.nsIURIFixup);
checkService("blocklist", Ci.nsIBlocklistService);
}

View File

@ -0,0 +1,106 @@
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
/**
* This file tests the Services.jsm module.
*/
////////////////////////////////////////////////////////////////////////////////
/// Globals
const Cc = Components.classes;
const Ci = Components.interfaces;
const Cu = Components.utils;
const Cr = Components.results;
Cu.import("resource://gre/modules/XPCOMUtils.jsm");
Cu.import("resource://gre/modules/Services.jsm");
function checkService(service, interface) {
do_print("Checking that Services." + service + " is an " + interface);
do_check_true(service in Services);
do_check_true(Services[service] instanceof interface);
}
////////////////////////////////////////////////////////////////////////////////
/// Tests
function run_test()
{
do_get_profile();
checkService("appShell", Ci.nsIAppShellService);
checkService("appinfo", Ci.nsIXULRuntime);
checkService("blocklist", Ci.nsIBlocklistService);
checkService("cache", Ci.nsICacheService);
checkService("clipboard", Ci.nsIClipboard);
checkService("console", Ci.nsIConsoleService);
checkService("contentPrefs", Ci.nsIContentPrefService);
checkService("cookies", Ci.nsICookieManager2);
checkService("dirsvc", Ci.nsIDirectoryService);
checkService("dirsvc", Ci.nsIProperties);
checkService("DOMRequest", Ci.nsIDOMRequestService);
checkService("domStorageManager", Ci.nsIDOMStorageManager);
checkService("downloads", Ci.nsIDownloadManager);
checkService("droppedLinkHandler", Ci.nsIDroppedLinkHandler);
checkService("eTLD", Ci.nsIEffectiveTLDService);
checkService("focus", Ci.nsIFocusManager);
checkService("io", Ci.nsIIOService);
checkService("io", Ci.nsIIOService2);
checkService("locale", Ci.nsILocaleService);
checkService("logins", Ci.nsILoginManager);
checkService("obs", Ci.nsIObserverService);
checkService("perms", Ci.nsIPermissionManager);
checkService("prefs", Ci.nsIPrefBranch);
checkService("prefs", Ci.nsIPrefService);
checkService("prompt", Ci.nsIPromptService);
checkService("scriptSecurityManager", Ci.nsIScriptSecurityManager);
checkService("scriptloader", Ci.mozIJSSubScriptLoader);
checkService("startup", Ci.nsIAppStartup);
checkService("storage", Ci.mozIStorageService);
checkService("strings", Ci.nsIStringBundleService);
checkService("sysinfo", Ci.nsIPropertyBag2);
checkService("telemetry", Ci.nsITelemetry);
checkService("tm", Ci.nsIThreadManager);
checkService("uriFixup", Ci.nsIURIFixup);
checkService("urlFormatter", Ci.nsIURLFormatter);
checkService("vc", Ci.nsIVersionComparator);
checkService("wm", Ci.nsIWindowMediator);
checkService("ww", Ci.nsIWindowWatcher);
if ("nsIBrowserSearchService" in Ci) {
checkService("search", Ci.nsIBrowserSearchService);
}
// In xpcshell tests, the "@mozilla.org/xre/app-info;1" component implements
// only the nsIXULRuntime interface, but not nsIXULAppInfo. To test the
// service getter for the latter interface, we define a minimal mock factory
// that returns an object defining both interfaces.
let contractID = "@mozilla.org/xre/app-info;1";
let mockFactory = {
createInstance: function (aOuter, aIid) {
return {
QueryInterface: XPCOMUtils.generateQI([Ci.nsIXULRuntime,
Ci.nsIXULAppInfo]),
}.QueryInterface(aIid);
}
};
let registrar = Components.manager.QueryInterface(Ci.nsIComponentRegistrar);
let cid = registrar.contractIDToCID(contractID);
let oldFactory = Components.manager.getClassObject(Cc[contractID],
Ci.nsIFactory);
registrar.unregisterFactory(cid, oldFactory);
registrar.registerFactory(cid, "", contractID, mockFactory);
// We need to reload the module to update the lazy getter.
Cu.unload("resource://gre/modules/Services.jsm");
Cu.import("resource://gre/modules/Services.jsm");
checkService("appinfo", Ci.nsIXULAppInfo);
// Clean up.
registrar.unregisterFactory(cid, mockFactory);
registrar.registerFactory(cid, "", contractID, oldFactory);
Cu.unload("resource://gre/modules/Services.jsm");
}

View File

@ -9,6 +9,7 @@ tail =
[test_Promise.js]
[test_propertyListsUtils.js]
[test_readCertPrefs.js]
[test_Services.js]
[test_sqlite.js]
[test_task.js]
[test_TelemetryTimestamps.js]