forked from mirrors/gecko-dev
116 lines
3.2 KiB
JavaScript
116 lines
3.2 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
||
http://creativecommons.org/publicdomain/zero/1.0/ */
|
||
|
||
"use strict";
|
||
|
||
const { PasswordFileMigrator } = ChromeUtils.importESModule(
|
||
"resource:///modules/FileMigrators.sys.mjs"
|
||
);
|
||
const { LoginCSVImport } = ChromeUtils.importESModule(
|
||
"resource://gre/modules/LoginCSVImport.sys.mjs"
|
||
);
|
||
const { sinon } = ChromeUtils.importESModule(
|
||
"resource://testing-common/Sinon.sys.mjs"
|
||
);
|
||
const { MigrationWizardConstants } = ChromeUtils.importESModule(
|
||
"chrome://browser/content/migration/migration-wizard-constants.mjs"
|
||
);
|
||
|
||
add_setup(async function () {
|
||
Services.prefs.setBoolPref("signon.management.page.fileImport.enabled", true);
|
||
registerCleanupFunction(() => {
|
||
Services.prefs.clearUserPref("signon.management.page.fileImport.enabled");
|
||
});
|
||
});
|
||
|
||
/**
|
||
* Tests that the PasswordFileMigrator properly subclasses FileMigratorBase
|
||
* and delegates to the LoginCSVImport module.
|
||
*/
|
||
add_task(async function test_PasswordFileMigrator() {
|
||
let sandbox = sinon.createSandbox();
|
||
registerCleanupFunction(() => {
|
||
sandbox.restore();
|
||
});
|
||
|
||
let migrator = new PasswordFileMigrator();
|
||
Assert.ok(
|
||
migrator.constructor.key,
|
||
"PasswordFileMigrator implements static getter 'key'"
|
||
);
|
||
Assert.ok(
|
||
migrator.constructor.displayNameL10nID,
|
||
"PasswordFileMigrator implements static getter 'displayNameL10nID'"
|
||
);
|
||
Assert.ok(
|
||
await migrator.getFilePickerConfig(),
|
||
"PasswordFileMigrator returns something for getFilePickerConfig()"
|
||
);
|
||
Assert.ok(
|
||
migrator.displayedResourceTypes,
|
||
"PasswordFileMigrator returns something for displayedResourceTypes"
|
||
);
|
||
Assert.ok(migrator.enabled, "PasswordFileMigrator is enabled.");
|
||
|
||
const IMPORT_SUMMARY = [
|
||
{
|
||
result: "added",
|
||
},
|
||
{
|
||
result: "added",
|
||
},
|
||
{
|
||
result: "modified",
|
||
},
|
||
];
|
||
const EXPECTED_SUCCESS_STATE = {
|
||
[MigrationWizardConstants.DISPLAYED_FILE_RESOURCE_TYPES.PASSWORDS_NEW]:
|
||
"2 added",
|
||
[MigrationWizardConstants.DISPLAYED_FILE_RESOURCE_TYPES.PASSWORDS_UPDATED]:
|
||
"1 updated",
|
||
};
|
||
const FAKE_PATH = "some/fake/path.csv";
|
||
|
||
let importFromCSVStub = sandbox
|
||
.stub(LoginCSVImport, "importFromCSV")
|
||
.callsFake(somePath => {
|
||
Assert.equal(somePath, FAKE_PATH, "Got expected path");
|
||
return Promise.resolve(IMPORT_SUMMARY);
|
||
});
|
||
let result = await migrator.migrate(FAKE_PATH);
|
||
|
||
Assert.ok(importFromCSVStub.called, "The stub should have been called.");
|
||
Assert.deepEqual(
|
||
result,
|
||
EXPECTED_SUCCESS_STATE,
|
||
"Got back the expected success state."
|
||
);
|
||
|
||
sandbox.restore();
|
||
});
|
||
|
||
/**
|
||
* Tests that the PasswordFileMigrator will throw an exception with a
|
||
* consistent error message if the LoginCSVImport function rejects.
|
||
*/
|
||
add_task(async function test_PasswordFileMigrator_exception() {
|
||
let sandbox = sinon.createSandbox();
|
||
registerCleanupFunction(() => {
|
||
sandbox.restore();
|
||
});
|
||
|
||
let migrator = new PasswordFileMigrator();
|
||
|
||
const FAKE_PATH = "some/fake/path.csv";
|
||
|
||
sandbox.stub(LoginCSVImport, "importFromCSV").callsFake(() => {
|
||
return Promise.reject("Some error");
|
||
});
|
||
|
||
await Assert.rejects(
|
||
migrator.migrate(FAKE_PATH),
|
||
/The file doesn’t include any valid password data/
|
||
);
|
||
|
||
sandbox.restore();
|
||
});
|