Bug 1364477 - Only getAll Address Profiles once at initialization. r=steveck

MozReview-Commit-ID: Hw1twbznDsY

--HG--
rename : browser/extensions/formautofill/test/unit/test_enabledStatus.js => browser/extensions/formautofill/test/unit/test_activeStatus.js
extra : rebase_source : 098db1d42c1811ef27302725f7ab7f528dcf7bc3
This commit is contained in:
Matthew Noorenberghe 2017-05-23 00:47:59 -04:00
Родитель 617b1fb255
Коммит cb12333c55
4 изменённых файлов: 109 добавлений и 131 удалений

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

@ -56,10 +56,9 @@ FormAutofillParent.prototype = {
QueryInterface: XPCOMUtils.generateQI([Ci.nsISupports, Ci.nsIObserver]), QueryInterface: XPCOMUtils.generateQI([Ci.nsISupports, Ci.nsIObserver]),
/** /**
* Whether Form Autofill is enabled in preferences. * Cache of the Form Autofill status (considering preferences and storage).
* Caches the latest value of this._getStatus().
*/ */
_enabled: false, _active: null,
/** /**
* Initializes ProfileStorage and registers the message handler. * Initializes ProfileStorage and registers the message handler.
@ -77,9 +76,7 @@ FormAutofillParent.prototype = {
Services.prefs.addObserver(ENABLED_PREF, this); Services.prefs.addObserver(ENABLED_PREF, this);
Services.obs.addObserver(this, "formautofill-storage-changed"); Services.obs.addObserver(this, "formautofill-storage-changed");
// Force to trigger the onStatusChanged function for setting listeners properly // Update the saved field names to compute the status and update child processes.
// while initizlization
this._setStatus(this._getStatus());
this._updateSavedFieldNames(); this._updateSavedFieldNames();
}, },
@ -103,11 +100,8 @@ FormAutofillParent.prototype = {
} }
case "nsPref:changed": { case "nsPref:changed": {
// Observe pref changes and update _enabled cache if status is changed. // Observe pref changes and update _active cache if status is changed.
let currentStatus = this._getStatus(); this._updateStatus();
if (currentStatus !== this._enabled) {
this._setStatus(currentStatus);
}
break; break;
} }
@ -118,10 +112,6 @@ FormAutofillParent.prototype = {
} }
this._updateSavedFieldNames(); this._updateSavedFieldNames();
let currentStatus = this._getStatus();
if (currentStatus !== this._enabled) {
this._setStatus(currentStatus);
}
break; break;
} }
@ -135,35 +125,36 @@ FormAutofillParent.prototype = {
* Broadcast the status to frames when the form autofill status changes. * Broadcast the status to frames when the form autofill status changes.
*/ */
_onStatusChanged() { _onStatusChanged() {
log.debug("_onStatusChanged: Status changed to", this._enabled); log.debug("_onStatusChanged: Status changed to", this._active);
Services.ppmm.broadcastAsyncMessage("FormAutofill:enabledStatus", this._enabled); Services.ppmm.broadcastAsyncMessage("FormAutofill:enabledStatus", this._active);
// Sync process data autofillEnabled to make sure the value up to date // Sync process data autofillEnabled to make sure the value up to date
// no matter when the new content process is initialized. // no matter when the new content process is initialized.
Services.ppmm.initialProcessData.autofillEnabled = this._enabled; Services.ppmm.initialProcessData.autofillEnabled = this._active;
}, },
/** /**
* Query pref and storage status to determine the overall status for * Query preference and storage status to determine the overall status of the
* form autofill feature. * form autofill feature.
* *
* @returns {boolean} status of form autofill feature * @returns {boolean} whether form autofill is active (enabled and has data)
*/ */
_getStatus() { _computeStatus() {
if (!Services.prefs.getBoolPref(ENABLED_PREF)) { if (!Services.prefs.getBoolPref(ENABLED_PREF)) {
return false; return false;
} }
return profileStorage.addresses.getAll({noComputedFields: true}).length > 0; return Services.ppmm.initialProcessData.autofillSavedFieldNames.size > 0;
}, },
/** /**
* Set status and trigger _onStatusChanged. * Update the status and trigger _onStatusChanged, if necessary.
*
* @param {boolean} newStatus The latest status we want to set for _enabled
*/ */
_setStatus(newStatus) { _updateStatus() {
this._enabled = newStatus; let wasActive = this._active;
this._active = this._computeStatus();
if (this._active !== wasActive) {
this._onStatusChanged(); this._onStatusChanged();
}
}, },
/** /**
@ -234,6 +225,7 @@ FormAutofillParent.prototype = {
}, },
_updateSavedFieldNames() { _updateSavedFieldNames() {
log.debug("_updateSavedFieldNames");
if (!Services.ppmm.initialProcessData.autofillSavedFieldNames) { if (!Services.ppmm.initialProcessData.autofillSavedFieldNames) {
Services.ppmm.initialProcessData.autofillSavedFieldNames = new Set(); Services.ppmm.initialProcessData.autofillSavedFieldNames = new Set();
} else { } else {
@ -256,5 +248,6 @@ FormAutofillParent.prototype = {
Services.ppmm.broadcastAsyncMessage("FormAutofill:savedFieldNames", Services.ppmm.broadcastAsyncMessage("FormAutofill:savedFieldNames",
Services.ppmm.initialProcessData.autofillSavedFieldNames); Services.ppmm.initialProcessData.autofillSavedFieldNames);
this._updateStatus();
}, },
}; };

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

@ -0,0 +1,87 @@
/*
* Test for status handling in Form Autofill Parent.
*/
"use strict";
Cu.import("resource://formautofill/FormAutofillParent.jsm");
Cu.import("resource://formautofill/ProfileStorage.jsm");
add_task(async function test_activeStatus_init() {
let formAutofillParent = new FormAutofillParent();
sinon.spy(formAutofillParent, "_updateStatus");
// Default status is null before initialization
do_check_eq(formAutofillParent._active, null);
do_check_eq(Services.ppmm.initialProcessData.autofillEnabled, undefined);
await formAutofillParent.init();
do_check_eq(formAutofillParent._updateStatus.called, true);
do_check_eq(Services.ppmm.initialProcessData.autofillEnabled, false);
formAutofillParent._uninit();
});
add_task(async function test_activeStatus_observe() {
let formAutofillParent = new FormAutofillParent();
sinon.stub(formAutofillParent, "_computeStatus");
sinon.spy(formAutofillParent, "_onStatusChanged");
// _active = _computeStatus() => No need to trigger _onStatusChanged
formAutofillParent._active = true;
formAutofillParent._computeStatus.returns(true);
formAutofillParent.observe(null, "nsPref:changed", "extensions.formautofill.addresses.enabled");
do_check_eq(formAutofillParent._onStatusChanged.called, false);
// _active != _computeStatus() => Need to trigger _onStatusChanged
formAutofillParent._computeStatus.returns(false);
formAutofillParent._onStatusChanged.reset();
formAutofillParent.observe(null, "nsPref:changed", "extensions.formautofill.addresses.enabled");
do_check_eq(formAutofillParent._onStatusChanged.called, true);
// profile added => Need to trigger _onStatusChanged
formAutofillParent._computeStatus.returns(!formAutofillParent._active);
formAutofillParent._onStatusChanged.reset();
formAutofillParent.observe(null, "formautofill-storage-changed", "add");
do_check_eq(formAutofillParent._onStatusChanged.called, true);
// profile removed => Need to trigger _onStatusChanged
formAutofillParent._computeStatus.returns(!formAutofillParent._active);
formAutofillParent._onStatusChanged.reset();
formAutofillParent.observe(null, "formautofill-storage-changed", "remove");
do_check_eq(formAutofillParent._onStatusChanged.called, true);
// profile updated => no need to trigger _onStatusChanged
formAutofillParent._computeStatus.returns(!formAutofillParent._active);
formAutofillParent._onStatusChanged.reset();
formAutofillParent.observe(null, "formautofill-storage-changed", "update");
do_check_eq(formAutofillParent._onStatusChanged.called, false);
});
add_task(async function test_activeStatus_computeStatus() {
let formAutofillParent = new FormAutofillParent();
do_register_cleanup(function cleanup() {
Services.prefs.clearUserPref("extensions.formautofill.addresses.enabled");
});
sinon.stub(profileStorage.addresses, "getAll");
profileStorage.addresses.getAll.returns([]);
// pref is enabled and profile is empty.
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", true);
do_check_eq(formAutofillParent._computeStatus(), false);
// pref is disabled and profile is empty.
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", false);
do_check_eq(formAutofillParent._computeStatus(), false);
profileStorage.addresses.getAll.returns([{"given-name": "John"}]);
formAutofillParent.observe(null, "formautofill-storage-changed", "add");
// pref is enabled and profile is not empty.
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", true);
do_check_eq(formAutofillParent._computeStatus(), true);
// pref is disabled and profile is not empty.
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", false);
do_check_eq(formAutofillParent._computeStatus(), false);
});

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

@ -1,102 +0,0 @@
/*
* Test for status handling in Form Autofill Parent.
*/
"use strict";
Cu.import("resource://formautofill/FormAutofillParent.jsm");
Cu.import("resource://formautofill/ProfileStorage.jsm");
add_task(async function test_enabledStatus_init() {
let formAutofillParent = new FormAutofillParent();
sinon.spy(formAutofillParent, "_setStatus");
// Default status is false before initialization
do_check_eq(formAutofillParent._enabled, false);
do_check_eq(Services.ppmm.initialProcessData.autofillEnabled, undefined);
await formAutofillParent.init();
do_check_eq(formAutofillParent._setStatus.called, true);
do_check_eq(Services.ppmm.initialProcessData.autofillEnabled, false);
formAutofillParent._uninit();
});
add_task(function* test_enabledStatus_observe() {
let formAutofillParent = new FormAutofillParent();
sinon.stub(formAutofillParent, "_getStatus");
sinon.spy(formAutofillParent, "_setStatus");
sinon.stub(formAutofillParent, "_updateSavedFieldNames");
// _enabled = _getStatus() => No need to trigger onStatusChanged
formAutofillParent._enabled = true;
formAutofillParent._getStatus.returns(true);
formAutofillParent.observe(null, "nsPref:changed", "extensions.formautofill.addresses.enabled");
do_check_eq(formAutofillParent._setStatus.called, false);
// _enabled != _getStatus() => Need to trigger onStatusChanged
formAutofillParent._getStatus.returns(false);
formAutofillParent.observe(null, "nsPref:changed", "extensions.formautofill.addresses.enabled");
do_check_eq(formAutofillParent._setStatus.called, true);
// profile added => Need to trigger onStatusChanged
formAutofillParent._getStatus.returns(!formAutofillParent._enabled);
formAutofillParent._setStatus.reset();
formAutofillParent.observe(null, "formautofill-storage-changed", "add");
do_check_eq(formAutofillParent._setStatus.called, true);
// profile removed => Need to trigger onStatusChanged
formAutofillParent._getStatus.returns(!formAutofillParent._enabled);
formAutofillParent._setStatus.reset();
formAutofillParent.observe(null, "formautofill-storage-changed", "remove");
do_check_eq(formAutofillParent._setStatus.called, true);
// profile updated => no need to trigger onStatusChanged
formAutofillParent._getStatus.returns(!formAutofillParent._enabled);
formAutofillParent._setStatus.reset();
formAutofillParent.observe(null, "formautofill-storage-changed", "update");
do_check_eq(formAutofillParent._setStatus.called, false);
});
add_task(function* test_enabledStatus_getStatus() {
let formAutofillParent = new FormAutofillParent();
do_register_cleanup(function cleanup() {
Services.prefs.clearUserPref("extensions.formautofill.addresses.enabled");
});
sinon.stub(profileStorage.addresses, "getAll");
profileStorage.addresses.getAll.returns([]);
// pref is enabled and profile is empty.
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", true);
do_check_eq(formAutofillParent._getStatus(), false);
// pref is disabled and profile is empty.
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", false);
do_check_eq(formAutofillParent._getStatus(), false);
profileStorage.addresses.getAll.returns(["test-profile"]);
// pref is enabled and profile is not empty.
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", true);
do_check_eq(formAutofillParent._getStatus(), true);
// pref is disabled and profile is not empty.
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", false);
do_check_eq(formAutofillParent._getStatus(), false);
});
add_task(function* test_enabledStatus_setStatus() {
let formAutofillParent = new FormAutofillParent();
sinon.spy(formAutofillParent, "_onStatusChanged");
formAutofillParent._setStatus(true);
do_check_eq(formAutofillParent._enabled, true);
do_check_eq(Services.ppmm.initialProcessData.autofillEnabled, true);
do_check_eq(formAutofillParent._onStatusChanged.called, true);
formAutofillParent._onStatusChanged.reset();
formAutofillParent._setStatus(false);
do_check_eq(formAutofillParent._enabled, false);
do_check_eq(Services.ppmm.initialProcessData.autofillEnabled, false);
do_check_eq(formAutofillParent._onStatusChanged.called, true);
});

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

@ -16,11 +16,11 @@ support-files =
[heuristics/third_party/test_Sears.js] [heuristics/third_party/test_Sears.js]
[heuristics/third_party/test_Staples.js] [heuristics/third_party/test_Staples.js]
[heuristics/third_party/test_Walmart.js] [heuristics/third_party/test_Walmart.js]
[test_activeStatus.js]
[test_addressRecords.js] [test_addressRecords.js]
[test_autofillFormFields.js] [test_autofillFormFields.js]
[test_collectFormFields.js] [test_collectFormFields.js]
[test_creditCardRecords.js] [test_creditCardRecords.js]
[test_enabledStatus.js]
[test_findLabelElements.js] [test_findLabelElements.js]
[test_getFormInputDetails.js] [test_getFormInputDetails.js]
[test_isCJKName.js] [test_isCJKName.js]