mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-09 13:25:00 +00:00
Bug 394717 - NS_ERROR_ILLEGAL_VALUE calling nsIExtensionManager.update when profile updates. patch=ajvincent, r=rstrong
This commit is contained in:
parent
423d30ba39
commit
5f1e8bc717
@ -301,9 +301,11 @@ interface nsIExtensionManager : nsISupports
|
||||
* installed version and synchronize the values.
|
||||
* @param listener
|
||||
* An nsIAddonUpdateCheckListener object which will be notified during
|
||||
* the update check process.
|
||||
* the update check process. If not null, the object's
|
||||
* onUpdateStarted() and onUpdateEnded() methods will be called even
|
||||
* if there are no items to update.
|
||||
*
|
||||
* @throws NS_ERROR_ILLEGAL_VALUE if any item is invalid, or if itemCount == 0.
|
||||
* @throws NS_ERROR_ILLEGAL_VALUE if any item is invalid.
|
||||
*/
|
||||
void update([array, size_is(itemCount)] in nsIUpdateItem items,
|
||||
in unsigned long itemCount,
|
||||
|
@ -5103,9 +5103,6 @@ ExtensionManager.prototype = {
|
||||
* See nsIExtensionManager.idl
|
||||
*/
|
||||
update: function(items, itemCount, updateCheckType, listener) {
|
||||
if (itemCount == 0)
|
||||
throw Cr.NS_ERROR_ILLEGAL_VALUE;
|
||||
|
||||
for (i = 0; i < itemCount; ++i) {
|
||||
var currItem = items[i];
|
||||
if (!currItem)
|
||||
@ -5850,6 +5847,9 @@ ExtensionItemUpdater.prototype = {
|
||||
this._listener.onAddonUpdateStarted(e);
|
||||
(new RDFItemUpdater(this)).checkForUpdates(e, aUpdateCheckType);
|
||||
}
|
||||
|
||||
if (this._listener && aItemCount == 0)
|
||||
this._listener.onUpdateEnded();
|
||||
},
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
82
toolkit/mozapps/extensions/test/unit/test_bug394717.js
Normal file
82
toolkit/mozapps/extensions/test/unit/test_bug394717.js
Normal file
@ -0,0 +1,82 @@
|
||||
/* ***** 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
|
||||
* Alexander J. Vincent <ajvincent@gmail.com>.
|
||||
*
|
||||
* Portions created by the Initial Developer are Copyright (C) 2007
|
||||
* the Initial Developer. All Rights Reserved.
|
||||
*
|
||||
* Contributor(s):
|
||||
*
|
||||
* Alternatively, the contents of this file may be used under the terms of
|
||||
* either 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 *****
|
||||
*/
|
||||
|
||||
const checkListener = {
|
||||
_onUpdateStartedCalled: false,
|
||||
_onUpdateEndedCalled: false,
|
||||
|
||||
// nsIAddonUpdateCheckListener
|
||||
onUpdateStarted: function onUpdateStarted() {
|
||||
this._onUpdateStartedCalled = true;
|
||||
},
|
||||
|
||||
// nsIAddonUpdateCheckListener
|
||||
onUpdateEnded: function onUpdateEnded() {
|
||||
this._onUpdateEndedCalled = true;
|
||||
},
|
||||
|
||||
// nsIAddonUpdateCheckListener
|
||||
onAddonUpdateStarted: function onAddonUpdateStarted(aAddon) {
|
||||
do_throw("Unexpected call to onAddonUpdateStarted!");
|
||||
},
|
||||
|
||||
// nsIAddonUpdateCheckListener
|
||||
onAddonUpdateEnded: function onAddonUpdateEnded(aAddon, aStatus) {
|
||||
do_throw("Unexpected call to onAddonUpdateEnded!");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Run the test.
|
||||
*/
|
||||
function run_test() {
|
||||
createAppInfo("xpcshell@tests.mozilla.org", "XPCShell", "5", "1.9");
|
||||
startupEM();
|
||||
const Ci = Components.interfaces;
|
||||
gEM.update([], 0, Ci.nsIExtensionManager.UPDATE_SYNC_COMPATIBILITY, checkListener);
|
||||
do_test_pending();
|
||||
do_timeout(5000, "run_test_pt2()");
|
||||
}
|
||||
|
||||
function run_test_pt2() {
|
||||
dump("Checking onUpdateStarted\n");
|
||||
do_check_true(checkListener._onUpdateStartedCalled);
|
||||
dump("Checking onUpdateEnded\n");
|
||||
do_check_true(checkListener._onUpdateEndedCalled);
|
||||
do_test_finished();
|
||||
}
|
Loading…
Reference in New Issue
Block a user