mirror of
https://github.com/bitwarden/browser
synced 2025-12-14 07:13:32 +00:00
* Create tracker that can await until expected observables are received. * Test dates are almost equal * Remove unused class method * Allow for updating active account in accout service fake * Correct observable tracker behavior Clarify documentation * Transition config service to state provider Updates the config fetching behavior to be lazy and ensure that any emitted value has been updated if older than a configurable value (statically compiled). If desired, config fetching can be ensured fresh through an async. * Update calls to config service in DI and bootstrapping * Migrate account server configs * Fix global config fetching * Test migration rollback * Adhere to implementation naming convention * Adhere to abstract class naming convention * Complete config abstraction rename * Remove unnecessary cli config service * Fix builds * Validate observable does not complete * Use token service to determine authed or unauthed config pull * Remove superfluous factory config * Name describe blocks after the thing they test * Remove implementation documentation Unfortunately the experience when linking to external documentation is quite poor. Instead of following the link and retrieving docs, you get a link that can be clicked to take you out of context to the docs. No link _does_ retrieve docs, but lacks indication in the implementation that documentation exists at all. On the balance, removing the link is the better experience. * Fix storybook
113 lines
2.7 KiB
TypeScript
113 lines
2.7 KiB
TypeScript
import { runMigrator } from "../migration-helper.spec";
|
|
|
|
import { AccountServerConfigMigrator } from "./49-move-account-server-configs";
|
|
|
|
describe("AccountServerConfigMigrator", () => {
|
|
const migrator = new AccountServerConfigMigrator(48, 49);
|
|
|
|
describe("all data", () => {
|
|
function toMigrate() {
|
|
return {
|
|
authenticatedAccounts: ["user1", "user2"],
|
|
user1: {
|
|
settings: {
|
|
serverConfig: {
|
|
config: "user1 server config",
|
|
},
|
|
},
|
|
},
|
|
user2: {
|
|
settings: {
|
|
serverConfig: {
|
|
config: "user2 server config",
|
|
},
|
|
},
|
|
},
|
|
};
|
|
}
|
|
|
|
function migrated() {
|
|
return {
|
|
authenticatedAccounts: ["user1", "user2"],
|
|
|
|
user1: {
|
|
settings: {},
|
|
},
|
|
user2: {
|
|
settings: {},
|
|
},
|
|
user_user1_config_serverConfig: {
|
|
config: "user1 server config",
|
|
},
|
|
user_user2_config_serverConfig: {
|
|
config: "user2 server config",
|
|
},
|
|
};
|
|
}
|
|
|
|
function rolledBack(previous: object) {
|
|
return {
|
|
...previous,
|
|
user_user1_config_serverConfig: null as unknown,
|
|
user_user2_config_serverConfig: null as unknown,
|
|
};
|
|
}
|
|
|
|
it("migrates", async () => {
|
|
const output = await runMigrator(migrator, toMigrate(), "migrate");
|
|
expect(output).toEqual(migrated());
|
|
});
|
|
|
|
it("rolls back", async () => {
|
|
const output = await runMigrator(migrator, migrated(), "rollback");
|
|
expect(output).toEqual(rolledBack(toMigrate()));
|
|
});
|
|
});
|
|
|
|
describe("missing parts", () => {
|
|
function toMigrate() {
|
|
return {
|
|
authenticatedAccounts: ["user1", "user2"],
|
|
user1: {
|
|
settings: {
|
|
serverConfig: {
|
|
config: "user1 server config",
|
|
},
|
|
},
|
|
},
|
|
user2: null as unknown,
|
|
};
|
|
}
|
|
|
|
function migrated() {
|
|
return {
|
|
authenticatedAccounts: ["user1", "user2"],
|
|
user1: {
|
|
settings: {},
|
|
},
|
|
user2: null as unknown,
|
|
user_user1_config_serverConfig: {
|
|
config: "user1 server config",
|
|
},
|
|
};
|
|
}
|
|
|
|
function rollback(previous: object) {
|
|
return {
|
|
...previous,
|
|
user_user1_config_serverConfig: null as unknown,
|
|
};
|
|
}
|
|
|
|
it("migrates", async () => {
|
|
const output = await runMigrator(migrator, toMigrate(), "migrate");
|
|
expect(output).toEqual(migrated());
|
|
});
|
|
|
|
it("rolls back", async () => {
|
|
const output = await runMigrator(migrator, migrated(), "rollback");
|
|
expect(output).toEqual(rollback(toMigrate()));
|
|
});
|
|
});
|
|
});
|