mirror of
https://github.com/bitwarden/browser.git
synced 2024-12-03 13:33:32 +01:00
780a563ce0
* refactor: move SCIM component to admin-console, refs EC-1011 * refactor: move scimProviderType to admin-console, refs EC-1011 * refactor: move scim-config.api to admin-console, refs EC-1011 * refactor: create models folder and nest existing api contents, refs EC-1011 * refactor: move scim-config to admin-console models, refs EC-1011 * refactor: move billing.component to billing, refs EC-1011 * refactor: remove nested app folder from new billing structure, refs EC-1011 * refactor: move organizations/billing to billing, refs EC-1011 * refactor: move add-credit and adjust-payment to billing/settings, refs EC-1011 * refactor: billing history/sync to billing, refs EC-1011 * refactor: move org plans, payment/method to billing/settings, refs EC-1011 * fix: update legacy file paths for payment-method and tax-info, refs EC-1011 * fix: update imports for scim component, refs EC-1011 * refactor: move subscription and tax-info into billing, refs EC-1011 * refactor: move user-subscription to billing, refs EC-1011 * refactor: move images/cards to billing and update base path, refs EC-1011 * refactor: move payment-method, plan subscription, and plan to billing, refs EC-1011 * refactor: move transaction-type to billing, refs EC-1011 * refactor: move billing-sync-config to billing, refs EC-1011 * refactor: move billing-sync and bit-pay-invoice request to billing, refs EC-1011 * refactor: move org subscription and tax info update requests to billing, refs EC-1011 * fix: broken paths to billing, refs EC-1011 * refactor: move payment request to billing, refs EC-1011 * fix: update remaining imports for payment-request, refs EC-1011 * refactor: move tax-info-update to billing, refs EC-1011 * refactor: move billing-payment, billing-history, and billing responses to billing, refs EC-1011 * refactor: move organization-subscription-responset to billing, refs EC-1011 * refactor: move payment and plan responses to billing, refs EC-1011 * refactor: move subscription response to billing ,refs EC-1011 * refactor: move tax info and rate responses to billing, refs EC-1011 * fix: update remaining path to base response for tax-rate response, refs EC-1011 * refactor: (browser) move organization-service to admin-console, refs EC-1011 * refactor: (browser) move organizaiton-service to admin-console, refs EC-1011 * refactor: (cli) move share command to admin-console, refs EC-1011 * refactor: move organization-collect request model to admin-console, refs EC-1011 * refactor: (web) move organization, collection/user responses to admin-console, refs EC-1011 * refactor: (cli) move selection-read-only to admin-console, refs EC-1011 * refactor: (desktop) move organization-filter to admin-console, refs EC-1011 * refactor: (web) move organization-switcher to admin-console, refs EC-1011 * refactor: (web) move access-selector to admin-console, refs EC-1011 * refactor: (web) move create folder to admin-console, refs EC-1011 * refactor: (web) move org guards folder to admin-console, refs EC-1011 * refactor: (web) move org layout to admin-console, refs EC-1011 * refactor: move manage collections to admin console, refs EC-1011 * refactor: (web) move collection-dialog to admin-console, refs EC-1011 * refactor: (web) move entity users/events and events component to admin-console, refs EC-1011 * refactor: (web) move groups/group-add-edit to admin-console, refs EC-1011 * refactor: (web) move manage, org-manage module, and user-confirm to admin-console, refs EC-1011 * refactor: (web) move people to admin-console, refs EC-1011 * refactor: (web) move reset-password to admin-console, refs EC-1011 * refactor: (web) move organization-routing and module to admin-console, refs EC-1011 * refactor: move admin-console and billing within app scope, refs EC-1011 * fix: update leftover merge conflicts, refs EC-1011 * refactor: (web) member-dialog to admin-console, refs EC-1011 * refactor: (web) move policies to admin-console, refs EC-1011 * refactor: (web) move reporting to admin-console, refs EC-1011 * refactor: (web) move settings to admin-console, refs EC-1011 * refactor: (web) move sponsorships to admin-console, refs EC-1011 * refactor: (web) move tools to admin-console, refs EC-1011 * refactor: (web) move users to admin-console, refs EC-1011 * refactor: (web) move collections to admin-console, refs EC-1011 * refactor: (web) move create-organization to admin-console, refs EC-1011 * refactor: (web) move licensed components to admin-console, refs EC-1011 * refactor: (web) move bit organization modules to admin-console, refs EC-1011 * fix: update leftover import statements for organizations.module, refs EC-1011 * refactor: (web) move personal vault and max timeout to admin-console, refs EC-1011 * refactor: (web) move providers to admin-console, refs EC-1011 * refactor: (libs) move organization service to admin-console, refs EC-1011 * refactor: (libs) move profile org/provider responses and other misc org responses to admin-console, refs EC-1011 * refactor: (libs) move provider request and selectionion-read-only request to admin-console, refs EC-1011 * fix: update missed import path for provider-user-update request, refs EC-1011 * refactor: (libs) move abstractions to admin-console, refs EC-1011 * refactor: (libs) move org/provider enums to admin-console, refs EC-1011 * fix: update downstream import statements from libs changes, refs EC-1011 * refactor: (libs) move data files to admin-console, refs EC-1011 * refactor: (libs) move domain to admin-console, refs EC-1011 * refactor: (libs) move request objects to admin-console, refs EC-1011 * fix: update downstream import changes from libs, refs EC-1011 * refactor: move leftover provider files to admin-console, refs EC-1011 * refactor: (browser) move group policy environment to admin-console, refs EC-1011 * fix: (browser) update downstream import statements, refs EC-1011 * fix: (desktop) update downstream libs moves, refs EC-1011 * fix: (cli) update downstream import changes from libs, refs EC-1011 * refactor: move org-auth related files to admin-console, refs EC-1011 * refactor: (libs) move request objects to admin-console, refs EC-1011 * refactor: move persmissions to admin-console, refs EC-1011 * refactor: move sponsored families to admin-console and fix libs changes, refs EC-1011 * refactor: move collections to admin-console, refs EC-1011 * refactor: move spec file back to spec scope, refs EC-1011 * fix: update downstream imports due to libs changes, refs EC-1011 * fix: udpate downstream import changes due to libs, refs EC-1011 * fix: update downstream imports due to libs changes, refs EC-1011 * fix: update downstream imports from libs changes, refs EC-1011 * fix: update path malformation in jslib-services.module, refs EC-1011 * fix: lint errors from improper casing, refs AC-1011 * fix: update downstream filename changes, refs AC-1011 * fix: (cli) update downstream filename changes, refs AC-1011 * fix: (desktop) update downstream filename changes, refs AC-1011 * fix: (browser) update downstream filename changes, refs AC-1011 * fix: lint errors, refs AC-1011 * fix: prettier, refs AC-1011 * fix: lint fixes for import order, refs AC-1011 * fix: update import path for provider user type, refs AC-1011 * fix: update new codes import paths for admin console structure, refs AC-1011 * fix: lint/prettier, refs AC-1011 * fix: update layout stories path, refs AC-1011 * fix: update comoponents card icons base variable in styles, refs AC-1011 * fix: update provider service path in permissions guard spec, refs AC-1011 * fix: update provider permission guard path, refs AC-1011 * fix: remove unecessary TODO for shared index export statement, refs AC-1011 * refactor: move browser-organization service and cli organization-user response out of admin-console, refs AC-1011 * refactor: move web/browser/desktop collections component to vault domain, refs AC-1011 * refactor: move organization.module out of admin-console scope, refs AC-1011 * fix: prettier, refs AC-1011 * refactor: move organizations-api-key.request out of admin-console scope, refs AC-1011
171 lines
4.8 KiB
TypeScript
171 lines
4.8 KiB
TypeScript
import { MockProxy, mock, any, mockClear } from "jest-mock-extended";
|
|
import { BehaviorSubject, firstValueFrom } from "rxjs";
|
|
|
|
import { StateService } from "@bitwarden/common/abstractions/state.service";
|
|
import { OrganizationData } from "@bitwarden/common/admin-console/models/data/organization.data";
|
|
import { OrganizationService } from "@bitwarden/common/admin-console/services/organization/organization.service";
|
|
|
|
describe("Organization Service", () => {
|
|
let organizationService: OrganizationService;
|
|
|
|
let stateService: MockProxy<StateService>;
|
|
let activeAccount: BehaviorSubject<string>;
|
|
let activeAccountUnlocked: BehaviorSubject<boolean>;
|
|
|
|
const resetStateService = async (
|
|
customizeStateService: (stateService: MockProxy<StateService>) => void
|
|
) => {
|
|
mockClear(stateService);
|
|
stateService = mock<StateService>();
|
|
stateService.activeAccount$ = activeAccount;
|
|
stateService.activeAccountUnlocked$ = activeAccountUnlocked;
|
|
customizeStateService(stateService);
|
|
organizationService = new OrganizationService(stateService);
|
|
await new Promise((r) => setTimeout(r, 50));
|
|
};
|
|
|
|
beforeEach(() => {
|
|
activeAccount = new BehaviorSubject("123");
|
|
activeAccountUnlocked = new BehaviorSubject(true);
|
|
|
|
stateService = mock<StateService>();
|
|
stateService.activeAccount$ = activeAccount;
|
|
stateService.activeAccountUnlocked$ = activeAccountUnlocked;
|
|
|
|
stateService.getOrganizations.calledWith(any()).mockResolvedValue({
|
|
"1": organizationData("1", "Test Org"),
|
|
});
|
|
|
|
organizationService = new OrganizationService(stateService);
|
|
});
|
|
|
|
afterEach(() => {
|
|
activeAccount.complete();
|
|
activeAccountUnlocked.complete();
|
|
});
|
|
|
|
it("getAll", async () => {
|
|
const orgs = await organizationService.getAll();
|
|
expect(orgs).toHaveLength(1);
|
|
const org = orgs[0];
|
|
expect(org).toEqual({
|
|
id: "1",
|
|
name: "Test Org",
|
|
identifier: "test",
|
|
});
|
|
});
|
|
|
|
describe("canManageSponsorships", () => {
|
|
it("can because one is available", async () => {
|
|
await resetStateService((stateService) => {
|
|
stateService.getOrganizations.mockResolvedValue({
|
|
"1": { ...organizationData("1", "Org"), familySponsorshipAvailable: true },
|
|
});
|
|
});
|
|
|
|
const result = await organizationService.canManageSponsorships();
|
|
expect(result).toBe(true);
|
|
});
|
|
|
|
it("can because one is used", async () => {
|
|
await resetStateService((stateService) => {
|
|
stateService.getOrganizations.mockResolvedValue({
|
|
"1": { ...organizationData("1", "Test Org"), familySponsorshipFriendlyName: "Something" },
|
|
});
|
|
});
|
|
|
|
const result = await organizationService.canManageSponsorships();
|
|
expect(result).toBe(true);
|
|
});
|
|
|
|
it("can not because one isn't available or taken", async () => {
|
|
await resetStateService((stateService) => {
|
|
stateService.getOrganizations.mockResolvedValue({
|
|
"1": { ...organizationData("1", "Org"), familySponsorshipFriendlyName: null },
|
|
});
|
|
});
|
|
|
|
const result = await organizationService.canManageSponsorships();
|
|
expect(result).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe("get", () => {
|
|
it("exists", async () => {
|
|
const result = organizationService.get("1");
|
|
|
|
expect(result).toEqual({
|
|
id: "1",
|
|
name: "Test Org",
|
|
identifier: "test",
|
|
});
|
|
});
|
|
|
|
it("does not exist", async () => {
|
|
const result = organizationService.get("2");
|
|
|
|
expect(result).toBe(undefined);
|
|
});
|
|
});
|
|
|
|
it("upsert", async () => {
|
|
await organizationService.upsert(organizationData("2", "Test 2"));
|
|
|
|
expect(await firstValueFrom(organizationService.organizations$)).toEqual([
|
|
{
|
|
id: "1",
|
|
name: "Test Org",
|
|
identifier: "test",
|
|
},
|
|
{
|
|
id: "2",
|
|
name: "Test 2",
|
|
identifier: "test",
|
|
},
|
|
]);
|
|
});
|
|
|
|
describe("getByIdentifier", () => {
|
|
it("exists", async () => {
|
|
const result = organizationService.getByIdentifier("test");
|
|
|
|
expect(result).toEqual({
|
|
id: "1",
|
|
name: "Test Org",
|
|
identifier: "test",
|
|
});
|
|
});
|
|
|
|
it("does not exist", async () => {
|
|
const result = organizationService.getByIdentifier("blah");
|
|
|
|
expect(result).toBeUndefined();
|
|
});
|
|
});
|
|
|
|
describe("delete", () => {
|
|
it("exists", async () => {
|
|
await organizationService.delete("1");
|
|
|
|
expect(stateService.getOrganizations).toHaveBeenCalledTimes(2);
|
|
|
|
expect(stateService.setOrganizations).toHaveBeenCalledTimes(1);
|
|
});
|
|
|
|
it("does not exist", async () => {
|
|
organizationService.delete("1");
|
|
|
|
expect(stateService.getOrganizations).toHaveBeenCalledTimes(2);
|
|
});
|
|
});
|
|
|
|
function organizationData(id: string, name: string) {
|
|
const data = new OrganizationData({} as any);
|
|
data.id = id;
|
|
data.name = name;
|
|
data.identifier = "test";
|
|
|
|
return data;
|
|
}
|
|
});
|