mirror of
https://github.com/bitwarden/browser
synced 2025-12-18 09:13:33 +00:00
* Add `clientType` to MigrationHelper * PM-7766 - Fix migration builder tests to take new clientType into account. Co-authored-by: Justin Baur <19896123+justindbaur@users.noreply.github.com> * PM-7766 - Add client type to migration builder tests. * PM-7766 - Fix migration-helper.spec tests. * PM-7766 - Fix migrator.spec.ts --------- Co-authored-by: Jared Snider <jsnider@bitwarden.com>
82 lines
2.9 KiB
TypeScript
82 lines
2.9 KiB
TypeScript
import { mock, MockProxy } from "jest-mock-extended";
|
|
|
|
// eslint-disable-next-line import/no-restricted-paths -- Needed client type enum
|
|
import { ClientType } from "../enums";
|
|
// eslint-disable-next-line import/no-restricted-paths -- Needed to print log messages
|
|
import { LogService } from "../platform/abstractions/log.service";
|
|
// eslint-disable-next-line import/no-restricted-paths -- Needed to interface with storage locations
|
|
import { AbstractStorageService } from "../platform/abstractions/storage.service";
|
|
|
|
import { MigrationHelper } from "./migration-helper";
|
|
import { Migrator } from "./migrator";
|
|
|
|
describe("migrator default methods", () => {
|
|
class TestMigrator extends Migrator<0, 1> {
|
|
async migrate(helper: MigrationHelper): Promise<void> {
|
|
await helper.set("test", "test");
|
|
}
|
|
async rollback(helper: MigrationHelper): Promise<void> {
|
|
await helper.set("test", "rollback");
|
|
}
|
|
}
|
|
|
|
let storage: MockProxy<AbstractStorageService>;
|
|
let logService: MockProxy<LogService>;
|
|
let helper: MigrationHelper;
|
|
let sut: TestMigrator;
|
|
|
|
const clientTypes = Object.values(ClientType);
|
|
|
|
describe.each(clientTypes)("for client %s", (clientType) => {
|
|
beforeEach(() => {
|
|
storage = mock();
|
|
logService = mock();
|
|
helper = new MigrationHelper(0, storage, logService, "general", clientType);
|
|
sut = new TestMigrator(0, 1);
|
|
});
|
|
|
|
describe("shouldMigrate", () => {
|
|
describe("up", () => {
|
|
it("should return true if the current version equals the from version", async () => {
|
|
expect(await sut.shouldMigrate(helper, "up")).toBe(true);
|
|
});
|
|
|
|
it("should return false if the current version does not equal the from version", async () => {
|
|
helper.currentVersion = 1;
|
|
expect(await sut.shouldMigrate(helper, "up")).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe("down", () => {
|
|
it("should return true if the current version equals the to version", async () => {
|
|
helper.currentVersion = 1;
|
|
expect(await sut.shouldMigrate(helper, "down")).toBe(true);
|
|
});
|
|
|
|
it("should return false if the current version does not equal the to version", async () => {
|
|
expect(await sut.shouldMigrate(helper, "down")).toBe(false);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe("updateVersion", () => {
|
|
describe("up", () => {
|
|
it("should update the version", async () => {
|
|
await sut.updateVersion(helper, "up");
|
|
expect(storage.save).toBeCalledWith("stateVersion", 1);
|
|
expect(helper.currentVersion).toBe(1);
|
|
});
|
|
});
|
|
|
|
describe("down", () => {
|
|
it("should update the version", async () => {
|
|
helper.currentVersion = 1;
|
|
await sut.updateVersion(helper, "down");
|
|
expect(storage.save).toBeCalledWith("stateVersion", 0);
|
|
expect(helper.currentVersion).toBe(0);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|