/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*-
* vim: sw=2 ts=2 sts=2 tw=78 expandtab :
* 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/. */
var manifests = [do_get_file(
"data/test_no_remote_registration.manifest")];
registerManifests(manifests);
function ProtocolHandler(aScheme) {
this.scheme = aScheme;
}
ProtocolHandler.prototype = {
allowPort: () =>
false,
newChannel() {
throw Components.Exception(
"", Cr.NS_ERROR_NOT_IMPLEMENTED);
},
QueryInterface: ChromeUtils.generateQI([
"nsIProtocolHandler"]),
};
var testProtocols = [
// It doesn't matter if it has this flag - the only flag we accept is
// URI_IS_LOCAL_RESOURCE.
{
scheme:
"moz-protocol-ui-resource",
flags: Ci.nsIProtocolHandler.URI_IS_UI_RESOURCE,
shouldRegister:
false,
},
// It doesn't matter if it has this flag - the only flag we accept is
// URI_IS_LOCAL_RESOURCE.
{
scheme:
"moz-protocol-local-file",
flags: Ci.nsIProtocolHandler.URI_IS_LOCAL_FILE,
shouldRegister:
false,
},
// This clearly is non-local
{
scheme:
"moz-protocol-loadable-by-anyone",
flags: Ci.nsIProtocolHandler.URI_LOADABLE_BY_ANYONE,
shouldRegister:
false,
},
// This should always be last (unless we add more flags that are OK)
{
scheme:
"moz-protocol-local-resource",
flags: Ci.nsIProtocolHandler.URI_IS_LOCAL_RESOURCE,
shouldRegister:
true,
},
];
function run_test() {
const { newAppInfo } = ChromeUtils.importESModule(
"resource://testing-common/AppInfo.sys.mjs"
);
let XULAppInfo = newAppInfo({
name:
"XPCShell",
ID:
"{39885e5f-f6b4-4e2a-87e5-6259ecf79011}",
version:
"5",
platformVersion:
"1.9",
});
const uuidGenerator = Services.uuid;
let XULAppInfoFactory = {
// These two are used when we register all our factories (and unregister)
CID: uuidGenerator.generateUUID(),
scheme:
"XULAppInfo",
contractID:
"@mozilla.org/xre/app-info;1",
createInstance(iid) {
return XULAppInfo.QueryInterface(iid);
},
};
for (let protocol of testProtocols) {
Services.io.registerProtocolHandler(
protocol.scheme,
new ProtocolHandler(protocol.scheme),
protocol.flags,
-1
);
}
let registrar = Components.manager.QueryInterface(Ci.nsIComponentRegistrar);
// Register the XULAppInfoFactory
// Make sure the class ID has not already been registered
let old_factory = { CID:
"", factory:
null };
if (!registrar.isCIDRegistered(XULAppInfoFactory.CID)) {
// Check to see if a contract was already registered and
// register it if it is not. Otherwise, store the previous one
// to be restored later and register the new one.
if (registrar.isContractIDRegistered(XULAppInfoFactory.contractID)) {
dump(
XULAppInfoFactory.scheme +
" is already registered. Storing currently registered object for restoration later."
);
old_factory.CID = registrar.contractIDToCID(XULAppInfoFactory.contractID);
old_factory.factory = Components.manager.getClassObject(
Cc[XULAppInfoFactory.contractID],
Ci.nsIFactory
);
}
else {
dump(
XULAppInfoFactory.scheme +
" has never been registered. Registering..."
);
}
registrar.registerFactory(
XULAppInfoFactory.CID,
"test-" + XULAppInfoFactory.scheme,
XULAppInfoFactory.contractID,
XULAppInfoFactory
);
}
else {
do_throw(
"CID " + XULAppInfoFactory.CID +
" has already been registered!");
}
// Check for new chrome
let cr = Cc[
"@mozilla.org/chrome/chrome-registry;1"].getService(
Ci.nsIChromeRegistry
);
cr.checkForNewChrome();
// See if our various things were able to register
let registrationTypes = [
"content",
"locale",
"skin",
"override",
"resource"];
for (let i = 0; i < testProtocols.length; i++) {
let protocol = testProtocols[i];
for (let j = 0; j < registrationTypes.length; j++) {
let type = registrationTypes[j];
dump(
"Testing protocol '" + protocol.scheme +
"' with type '" + type +
"'\n"
);
let expectedURI = protocol.scheme +
"://foo/";
let sourceURI =
"chrome://" + protocol.scheme + "/" + type + "/";
switch (type) {
case "content":
expectedURI += protocol.scheme +
".xul";
break;
case "locale":
expectedURI += protocol.scheme +
".dtd";
break;
case "skin":
expectedURI += protocol.scheme +
".css";
break;
case "override":
sourceURI =
"chrome://good-package/content/override-" +
protocol.scheme +
".xul";
break;
case "resource":
sourceURI =
"resource://" + protocol.scheme + "/";
break;
}
try {
sourceURI = Services.io.newURI(sourceURI);
let uri;
if (type ==
"resource") {
// resources go about a slightly different way than everything else
let rph = Services.io
.getProtocolHandler(
"resource")
.QueryInterface(Ci.nsIResProtocolHandler);
// this throws for packages that are not registered
uri = rph.resolveURI(sourceURI);
}
else {
// this throws for packages that are not registered
uri = cr.convertChromeURL(sourceURI).spec;
}
if (protocol.shouldRegister) {
Assert.equal(expectedURI, uri);
}
else {
// Overrides will not throw, so we'll get to here. We want to make
// sure that the two strings are not the same in this situation.
Assert.notEqual(expectedURI, uri);
}
}
catch (e) {
if (protocol.shouldRegister) {
dump(e +
"\n");
do_throw(
"Should have registered our URI for protocol " + protocol.scheme
);
}
}
}
}
// Unregister our protocol handlers so we do not leak
for (let protocol of testProtocols) {
Services.io.unregisterProtocolHandler(protocol.scheme);
}
// Unregister XULAppInfoFactory
registrar.unregisterFactory(XULAppInfoFactory.CID, XULAppInfoFactory);
if (old_factory.factory !=
null) {
registrar.registerFactory(
old_factory.CID,
"",
XULAppInfoFactory.contractID,
null
);
}
}