Fix the TestRegistrationOrder test: we no longer support deferred registration.

This commit is contained in:
Benjamin Smedberg 2010-06-22 13:26:23 -04:00
Родитель 31381bcc63
Коммит a89e5e3db3
7 изменённых файлов: 14 добавлений и 336 удалений

Просмотреть файл

@ -132,12 +132,6 @@ nsresult TestRegular()
kCoreServiceA_CID, kExtServiceA_CID);
}
nsresult TestDeferred()
{
return execRegOrderTest("TestDeferred", SERVICE_B_CONTRACT_ID,
kCoreServiceB_CID, kExtServiceB_CID);
}
static already_AddRefed<nsILocalFile>
GetRegDirectory(const char* basename, const char* dirname)
{
@ -172,8 +166,6 @@ int main(int argc, char** argv)
int rv = 0;
if (NS_FAILED(TestRegular()))
rv = 1;
if (NS_FAILED(TestDeferred()))
rv = 1;
return rv;
}

Просмотреть файл

@ -61,51 +61,11 @@ var gRegTestCoreComponent =
lockFactory: function (aDoLock) {}
};
var gRegTestCoreComponentModule =
{
kClassName: "RegTestCoreComponent",
kClassID: Components.ID("{56ab1cd4-ac44-4f86-8104-171f8b8f2fc7}"),
kContractID: "@mozilla.org/RegTestServiceA;1",
kICompReg: Components.interfaces.nsIComponentRegistrar,
const kClassID = Components.ID("{56ab1cd4-ac44-4f86-8104-171f8b8f2fc7}");
/* nsISupports implementation. */
QueryInterface: function (aIID)
{
if (aIID.equals(Components.interfaces.nsIModule) ||
aIID.equals(Components.interfaces.nsISupports))
return this;
function NSGetFactory(aClassID) {
if (!aClassID.equals(kClassID))
throw Components.results.NS_ERROR_NOT_IMPLEMENTED;
throw Components.results.NS_ERROR_NO_INTERFACE;
},
/* nsIModule implementation. */
getClassObject: function (aCompMgr, aClassID, aIID)
{
if (!aClassID.equals(this.kClassID))
throw Components.results.NS_ERROR_NO_INTERFACE;
if (!aIID.equals(Components.interfaces.nsIFactory))
throw Components.results.NS_ERROR_NOT_IMPLEMENTED;
return gRegTestCoreComponent.QueryInterface(aIID);
},
registerSelf: function (aCompMgr, aFileSpec, aLocation, aType)
{
aCompMgr = aCompMgr.QueryInterface(this.kICompReg);
aCompMgr.registerFactoryLocation(this.kClassID, this.kClassName,
this.kContractID, aFileSpec, aLocation, aType);
},
unregisterSelf: function (aCompMgr, aFileSpec, aLocation)
{
aCompMgr = aCompMgr.QueryInterface(this.kICompReg);
aCompMgr.unregisterFactoryLocation(this.kClassID, aFileSpec);
},
canUnload: function (aCompMgr) { return true; }
};
function NSGetModule(aCompMgr, aFileSpec)
{
return gRegTestCoreComponentModule;
return gRegTestCoreComponent;
}

Просмотреть файл

@ -0,0 +1,2 @@
component {56ab1cd4-ac44-4f86-8104-171f8b8f2fc7} component.js
contract @mozilla.org/RegTestServiceA;1 {56ab1cd4-ac44-4f86-8104-171f8b8f2fc7}

Просмотреть файл

@ -1,119 +0,0 @@
/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim:set ts=2 sw=2 sts=2 et: */
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is mozilla.org code.
*
* The Initial Developer of the Original Code is
* Kathleen Brade <brade@pearlcrescent.com>
* Mark Smith <mcs@pearlcrescent.com>
* Portions created by the Initial Developer are Copyright (C) 2008
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
*
* Alternatively, the contents of this file may be used under the terms of
* either of the GNU General Public License Version 2 or later (the "GPL"),
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
var gRegTestCoreDeferredComponent =
{
/* nsISupports implementation. */
QueryInterface: function (aIID)
{
if (!aIID.equals(Components.interfaces.nsISupports) &&
!aIID.equals(Components.interfaces.nsIFactory))
throw Components.results.NS_ERROR_NO_INTERFACE;
return this;
},
/* nsIFactory implementation. */
createInstance: function (aOuter, aIID)
{
if (null != aOuter)
throw Components.results.NS_ERROR_NO_AGGREGATION;
return this.QueryInterface(aIID);
},
lockFactory: function (aDoLock) {}
};
var gRegTestCoreDeferredComponentModule =
{
kClassName: "RegTestCoreDeferredComponent",
kClassID: Components.ID("{d04d1298-6dac-459b-a13b-bcab235730a0}"),
kContractID: "@mozilla.org/RegTestServiceB;1",
kICompReg: Components.interfaces.nsIComponentRegistrar,
mIsFirstTime: true,
/* nsISupports implementation. */
QueryInterface: function (aIID)
{
if (aIID.equals(Components.interfaces.nsIModule) ||
aIID.equals(Components.interfaces.nsISupports))
return this;
throw Components.results.NS_ERROR_NO_INTERFACE;
},
/* nsIModule implementation. */
getClassObject: function (aCompMgr, aClassID, aIID)
{
if (!aClassID.equals(this.kClassID))
throw Components.results.NS_ERROR_NO_INTERFACE;
if (!aIID.equals(Components.interfaces.nsIFactory))
throw Components.results.NS_ERROR_NOT_IMPLEMENTED;
return gRegTestCoreDeferredComponent.QueryInterface(aIID);
},
registerSelf: function (aCompMgr, aFileSpec, aLocation, aType)
{
if (this.mIsFirstTime)
{
this.mIsFirstTime = false;
throw Components.results.NS_ERROR_FACTORY_REGISTER_AGAIN;
}
aCompMgr = aCompMgr.QueryInterface(this.kICompReg);
aCompMgr.registerFactoryLocation(this.kClassID, this.kClassName,
this.kContractID, aFileSpec, aLocation, aType);
},
unregisterSelf: function (aCompMgr, aFileSpec, aLocation)
{
aCompMgr = aCompMgr.QueryInterface(this.kICompReg);
aCompMgr.unregisterFactoryLocation(this.kClassID, aFileSpec);
},
canUnload: function (aCompMgr) { return true; }
};
function NSGetModule(aCompMgr, aFileSpec)
{
return gRegTestCoreDeferredComponentModule;
}

Просмотреть файл

@ -61,51 +61,11 @@ var gRegTestExtComponent =
lockFactory: function (aDoLock) {}
};
var gRegTestExtComponentModule =
const kClassID = Components.ID("{fe64efb7-c5ab-41a6-b639-e6c0f483181e}");
function NSGetFactory(cid)
{
kClassName: "RegTestExtComponent",
kClassID: Components.ID("{fe64efb7-c5ab-41a6-b639-e6c0f483181e}"),
kContractID: "@mozilla.org/RegTestServiceA;1",
kICompReg: Components.interfaces.nsIComponentRegistrar,
if (!cid.equals(kClassID))
throw Components.results.NS_ERROR_NOT_IMPLEMENTED;
/* nsISupports implementation. */
QueryInterface: function (aIID)
{
if (aIID.equals(Components.interfaces.nsIModule) ||
aIID.equals(Components.interfaces.nsISupports))
return this;
throw Components.results.NS_ERROR_NO_INTERFACE;
},
/* nsIModule implementation. */
getClassObject: function (aCompMgr, aClassID, aIID)
{
if (!aClassID.equals(this.kClassID))
throw Components.results.NS_ERROR_NO_INTERFACE;
if (!aIID.equals(Components.interfaces.nsIFactory))
throw Components.results.NS_ERROR_NOT_IMPLEMENTED;
return gRegTestExtComponent.QueryInterface(aIID);
},
registerSelf: function (aCompMgr, aFileSpec, aLocation, aType)
{
aCompMgr = aCompMgr.QueryInterface(this.kICompReg);
aCompMgr.registerFactoryLocation(this.kClassID, this.kClassName,
this.kContractID, aFileSpec, aLocation, aType);
},
unregisterSelf: function (aCompMgr, aFileSpec, aLocation)
{
aCompMgr = aCompMgr.QueryInterface(this.kICompReg);
aCompMgr.unregisterFactoryLocation(this.kClassID, aFileSpec);
},
canUnload: function (aCompMgr) { return true; }
};
function NSGetModule(aCompMgr, aFileSpec)
{
return gRegTestExtComponentModule;
return gRegTestExtComponent;
}

Просмотреть файл

@ -0,0 +1,2 @@
component {fe64efb7-c5ab-41a6-b639-e6c0f483181e} extComponent.js
contract @mozilla.org/RegTestServiceA;1 {fe64efb7-c5ab-41a6-b639-e6c0f483181e}

Просмотреть файл

@ -1,119 +0,0 @@
/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim:set ts=2 sw=2 sts=2 et: */
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is mozilla.org code.
*
* The Initial Developer of the Original Code is
* Kathleen Brade <brade@pearlcrescent.com>
* Mark Smith <mcs@pearlcrescent.com>
* Portions created by the Initial Developer are Copyright (C) 2008
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
*
* Alternatively, the contents of this file may be used under the terms of
* either of the GNU General Public License Version 2 or later (the "GPL"),
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
var gRegTestExtDeferredComponent =
{
/* nsISupports implementation. */
QueryInterface: function (aIID)
{
if (!aIID.equals(Components.interfaces.nsISupports) &&
!aIID.equals(Components.interfaces.nsIFactory))
throw Components.results.NS_ERROR_NO_INTERFACE;
return this;
},
/* nsIFactory implementation. */
createInstance: function (aOuter, aIID)
{
if (null != aOuter)
throw Components.results.NS_ERROR_NO_AGGREGATION;
return this.QueryInterface(aIID);
},
lockFactory: function (aDoLock) {}
};
var gRegTestExtDeferredComponentModule =
{
kClassName: "RegTestExtDeferredComponent",
kClassID: Components.ID("{e93dadeb-a6f6-4667-bbbc-ac8c6d440b20}"),
kContractID: "@mozilla.org/RegTestServiceB;1",
kICompReg: Components.interfaces.nsIComponentRegistrar,
mIsFirstTime: true,
/* nsISupports implementation. */
QueryInterface: function (aIID)
{
if (aIID.equals(Components.interfaces.nsIModule) ||
aIID.equals(Components.interfaces.nsISupports))
return this;
throw Components.results.NS_ERROR_NO_INTERFACE;
},
/* nsIModule implementation. */
getClassObject: function (aCompMgr, aClassID, aIID)
{
if (!aClassID.equals(this.kClassID))
throw Components.results.NS_ERROR_NO_INTERFACE;
if (!aIID.equals(Components.interfaces.nsIFactory))
throw Components.results.NS_ERROR_NOT_IMPLEMENTED;
return gRegTestExtDeferredComponent.QueryInterface(aIID);
},
registerSelf: function (aCompMgr, aFileSpec, aLocation, aType)
{
if (this.mIsFirstTime)
{
this.mIsFirstTime = false;
throw Components.results.NS_ERROR_FACTORY_REGISTER_AGAIN;
}
aCompMgr = aCompMgr.QueryInterface(this.kICompReg);
aCompMgr.registerFactoryLocation(this.kClassID, this.kClassName,
this.kContractID, aFileSpec, aLocation, aType);
},
unregisterSelf: function (aCompMgr, aFileSpec, aLocation)
{
aCompMgr = aCompMgr.QueryInterface(this.kICompReg);
aCompMgr.unregisterFactoryLocation(this.kClassID, aFileSpec);
},
canUnload: function (aCompMgr) { return true; }
};
function NSGetModule(aCompMgr, aFileSpec)
{
return gRegTestExtDeferredComponentModule;
}