forked from mirrors/gecko-dev
Backed out changeset fc97f5b5e65d (bug 1449055) Backed out changeset 45306ff933fe (bug 1449055) Backed out changeset da3100049ef2 (bug 1449055) --HG-- rename : browser/extensions/formautofill/api.js => browser/extensions/formautofill/bootstrap.js rename : browser/extensions/formautofill/manifest.json => browser/extensions/formautofill/install.rdf.in rename : browser/extensions/formautofill/skin/shared/autocomplete-item-shared.css => browser/extensions/formautofill/skin/shared/autocomplete-item.css rename : browser/extensions/formautofill/skin/shared/editDialog-shared.css => browser/extensions/formautofill/skin/shared/editDialog.css
106 lines
5.1 KiB
JavaScript
106 lines
5.1 KiB
JavaScript
/*
|
|
* Test for status handling in Form Autofill Parent.
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
let {FormAutofillParent} = ChromeUtils.import("resource://formautofill/FormAutofillParent.jsm", {});
|
|
|
|
add_task(async function test_activeStatus_init() {
|
|
let formAutofillParent = new FormAutofillParent();
|
|
sinon.spy(formAutofillParent, "_updateStatus");
|
|
|
|
// Default status is null before initialization
|
|
Assert.equal(formAutofillParent._active, null);
|
|
Assert.equal(Services.ppmm.initialProcessData.autofillEnabled, undefined);
|
|
|
|
await formAutofillParent.init();
|
|
// init shouldn't call updateStatus since that requires storage which will
|
|
// lead to startup time regressions.
|
|
Assert.equal(formAutofillParent._updateStatus.called, false);
|
|
Assert.equal(Services.ppmm.initialProcessData.autofillEnabled, undefined);
|
|
|
|
// Initialize profile storage
|
|
await formAutofillParent.formAutofillStorage.initialize();
|
|
// Upon first initializing profile storage, status should be computed.
|
|
Assert.equal(formAutofillParent._updateStatus.called, true);
|
|
Assert.equal(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");
|
|
formAutofillParent.observe(null, "nsPref:changed", "extensions.formautofill.creditCards.enabled");
|
|
Assert.equal(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");
|
|
formAutofillParent.observe(null, "nsPref:changed", "extensions.formautofill.creditCards.enabled");
|
|
Assert.equal(formAutofillParent._onStatusChanged.called, true);
|
|
|
|
// profile changed => Need to trigger _onStatusChanged
|
|
["add", "update", "remove", "reconcile"].forEach(event => {
|
|
formAutofillParent._computeStatus.returns(!formAutofillParent._active);
|
|
formAutofillParent._onStatusChanged.reset();
|
|
formAutofillParent.observe(null, "formautofill-storage-changed", event);
|
|
Assert.equal(formAutofillParent._onStatusChanged.called, true);
|
|
});
|
|
|
|
// profile metadata updated => No need to trigger _onStatusChanged
|
|
formAutofillParent._computeStatus.returns(!formAutofillParent._active);
|
|
formAutofillParent._onStatusChanged.reset();
|
|
formAutofillParent.observe(null, "formautofill-storage-changed", "notifyUsed");
|
|
Assert.equal(formAutofillParent._onStatusChanged.called, false);
|
|
});
|
|
|
|
add_task(async function test_activeStatus_computeStatus() {
|
|
let formAutofillParent = new FormAutofillParent();
|
|
registerCleanupFunction(function cleanup() {
|
|
Services.prefs.clearUserPref("extensions.formautofill.addresses.enabled");
|
|
Services.prefs.clearUserPref("extensions.formautofill.creditCards.enabled");
|
|
});
|
|
|
|
sinon.stub(formAutofillParent.formAutofillStorage.addresses, "getAll");
|
|
formAutofillParent.formAutofillStorage.addresses.getAll.returns([]);
|
|
|
|
// pref is enabled and profile is empty.
|
|
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", true);
|
|
Services.prefs.setBoolPref("extensions.formautofill.creditCards.enabled", true);
|
|
Assert.equal(formAutofillParent._computeStatus(), false);
|
|
|
|
// pref is disabled and profile is empty.
|
|
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", false);
|
|
Services.prefs.setBoolPref("extensions.formautofill.creditCards.enabled", false);
|
|
Assert.equal(formAutofillParent._computeStatus(), false);
|
|
|
|
formAutofillParent.formAutofillStorage.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);
|
|
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", true);
|
|
Assert.equal(formAutofillParent._computeStatus(), true);
|
|
|
|
// pref is partial enabled and profile is not empty.
|
|
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", true);
|
|
Services.prefs.setBoolPref("extensions.formautofill.creditCards.enabled", false);
|
|
Assert.equal(formAutofillParent._computeStatus(), true);
|
|
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", false);
|
|
Services.prefs.setBoolPref("extensions.formautofill.creditCards.enabled", true);
|
|
Assert.equal(formAutofillParent._computeStatus(), true);
|
|
|
|
|
|
// pref is disabled and profile is not empty.
|
|
Services.prefs.setBoolPref("extensions.formautofill.addresses.enabled", false);
|
|
Services.prefs.setBoolPref("extensions.formautofill.creditCards.enabled", false);
|
|
Assert.equal(formAutofillParent._computeStatus(), false);
|
|
});
|