forked from mirrors/gecko-dev
MozReview-Commit-ID: CNlVNOI1mWw --HG-- extra : rebase_source : 2789e74d440f252730d2b2598a2b762ec8356aac
95 lines
4.1 KiB
JavaScript
95 lines
4.1 KiB
JavaScript
/*
|
|
* 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();
|
|
// init shouldn't call updateStatus since that requires storage which will
|
|
// lead to startup time regressions.
|
|
do_check_eq(formAutofillParent._updateStatus.called, false);
|
|
do_check_eq(Services.ppmm.initialProcessData.autofillEnabled, undefined);
|
|
|
|
// Initialize profile storage
|
|
await formAutofillParent.profileStorage.initialize();
|
|
// Upon first initializing profile storage, status should be computed.
|
|
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);
|
|
});
|