mirror of
https://github.com/bitwarden/browser.git
synced 2024-12-31 17:57:43 +01:00
a5a12a6723
* Create and register new libs/importer Create package.json Create tsconfig Create jest.config Extend shared and root tsconfig and jest.configs Register with eslint * Move importer-related files to libs/importer * Move importer-spec-related files to libs/importer Move import.service.spec * Update package-lock.json * Set CODEOWNERS for new libs/importer * Register libs/importer with cli and fix imports * Register libs/importer with web and fix imports * Move importOption into models Rename importOptions to import-options * Fix linting issues after updating prettier * Only expose necessary files from libs/importer Fix tsconfig files - Removes the trailing /index on imports in web/cli As the spec-files no longer can access the internals via @bitwarden/importer they import by path (../src/importers) * Add barrel files to vendors with more than one importer
125 lines
4.4 KiB
TypeScript
125 lines
4.4 KiB
TypeScript
import { Utils } from "@bitwarden/common/misc/utils";
|
|
|
|
import { KeeperCsvImporter } from "../src/importers";
|
|
|
|
import { testData as TestData } from "./test-data/keeper-csv/testdata.csv";
|
|
|
|
describe("Keeper CSV Importer", () => {
|
|
let importer: KeeperCsvImporter;
|
|
beforeEach(() => {
|
|
importer = new KeeperCsvImporter();
|
|
});
|
|
|
|
it("should parse login data", async () => {
|
|
const result = await importer.parse(TestData);
|
|
expect(result != null).toBe(true);
|
|
|
|
const cipher = result.ciphers.shift();
|
|
expect(cipher.name).toEqual("Bar");
|
|
expect(cipher.login.username).toEqual("john.doe@example.com");
|
|
expect(cipher.login.password).toEqual("1234567890abcdef");
|
|
expect(cipher.login.uris.length).toEqual(1);
|
|
const uriView = cipher.login.uris.shift();
|
|
expect(uriView.uri).toEqual("https://example.com/");
|
|
expect(cipher.notes).toEqual("These are some notes.");
|
|
|
|
const cipher2 = result.ciphers.shift();
|
|
expect(cipher2.name).toEqual("Bar 1");
|
|
expect(cipher2.login.username).toEqual("john.doe1@example.com");
|
|
expect(cipher2.login.password).toEqual("234567890abcdef1");
|
|
expect(cipher2.login.uris.length).toEqual(1);
|
|
const uriView2 = cipher2.login.uris.shift();
|
|
expect(uriView2.uri).toEqual("https://an.example.com/");
|
|
expect(cipher2.notes).toBeNull();
|
|
|
|
const cipher3 = result.ciphers.shift();
|
|
expect(cipher3.name).toEqual("Bar 2");
|
|
expect(cipher3.login.username).toEqual("john.doe2@example.com");
|
|
expect(cipher3.login.password).toEqual("34567890abcdef12");
|
|
expect(cipher3.notes).toBeNull();
|
|
expect(cipher3.login.uris.length).toEqual(1);
|
|
const uriView3 = cipher3.login.uris.shift();
|
|
expect(uriView3.uri).toEqual("https://another.example.com/");
|
|
});
|
|
|
|
it("should import TOTP when present", async () => {
|
|
const result = await importer.parse(TestData);
|
|
expect(result != null).toBe(true);
|
|
|
|
const cipher = result.ciphers.shift();
|
|
expect(cipher.login.totp).toBeNull();
|
|
|
|
const cipher2 = result.ciphers.shift();
|
|
expect(cipher2.login.totp).toBeNull();
|
|
|
|
const cipher3 = result.ciphers.shift();
|
|
expect(cipher3.login.totp).toEqual(
|
|
"otpauth://totp/Amazon:me@company.com?secret=JBSWY3DPEHPK3PXP&issuer=Amazon&algorithm=SHA1&digits=6&period=30"
|
|
);
|
|
});
|
|
|
|
it("should parse custom fields", async () => {
|
|
const result = await importer.parse(TestData);
|
|
expect(result != null).toBe(true);
|
|
|
|
const cipher = result.ciphers.shift();
|
|
expect(cipher.fields).toBeNull();
|
|
|
|
const cipher2 = result.ciphers.shift();
|
|
expect(cipher2.fields.length).toBe(2);
|
|
expect(cipher2.fields[0].name).toEqual("Account ID");
|
|
expect(cipher2.fields[0].value).toEqual("12345");
|
|
expect(cipher2.fields[1].name).toEqual("Org ID");
|
|
expect(cipher2.fields[1].value).toEqual("54321");
|
|
|
|
const cipher3 = result.ciphers.shift();
|
|
expect(cipher3.fields[0].name).toEqual("Account ID");
|
|
expect(cipher3.fields[0].value).toEqual("23456");
|
|
});
|
|
|
|
it("should create folders, with subfolders and relationships", async () => {
|
|
const result = await importer.parse(TestData);
|
|
expect(result != null).toBe(true);
|
|
|
|
const folders = result.folders;
|
|
expect(folders).not.toBeNull();
|
|
expect(folders.length).toBe(2);
|
|
|
|
const folder1 = folders.shift();
|
|
expect(folder1.name).toBe("Foo");
|
|
|
|
//With subfolders
|
|
const folder2 = folders.shift();
|
|
expect(folder2.name).toBe("Foo/Baz");
|
|
|
|
// [Cipher, Folder]
|
|
expect(result.folderRelationships.length).toBe(3);
|
|
expect(result.folderRelationships[0]).toEqual([0, 0]);
|
|
expect(result.folderRelationships[1]).toEqual([1, 0]);
|
|
expect(result.folderRelationships[2]).toEqual([2, 1]);
|
|
});
|
|
|
|
it("should create collections, with subcollections and relationships", async () => {
|
|
importer.organizationId = Utils.newGuid();
|
|
const result = await importer.parse(TestData);
|
|
expect(result != null).toBe(true);
|
|
|
|
const collections = result.collections;
|
|
expect(collections).not.toBeNull();
|
|
expect(collections.length).toBe(2);
|
|
|
|
const collections1 = collections.shift();
|
|
expect(collections1.name).toBe("Foo");
|
|
|
|
//With subCollection
|
|
const collections2 = collections.shift();
|
|
expect(collections2.name).toBe("Foo/Baz");
|
|
|
|
// [Cipher, Folder]
|
|
expect(result.collectionRelationships.length).toBe(3);
|
|
expect(result.collectionRelationships[0]).toEqual([0, 0]);
|
|
expect(result.collectionRelationships[1]).toEqual([1, 0]);
|
|
expect(result.collectionRelationships[2]).toEqual([2, 1]);
|
|
});
|
|
});
|