1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-10-27 11:02:16 +01:00
unleash.unleash/src/test/fixtures/fake-project-store.ts
andreas-unleash 92328f6c27
fix: stickiness (#3471)
<!-- Thanks for creating a PR! To make it easier for reviewers and
everyone else to understand what your changes relate to, please add some
relevant content to the headings below. Feel free to ignore or delete
sections that you don't think are relevant. Thank you! ❤️ -->
- Fixes project model/store
- Fixes UI sync issues when switching stickiness 


## About the changes
<!-- Describe the changes introduced. What are they and why are they
being introduced? Feel free to also add screenshots or steps to view the
changes if they're visual. -->

<!-- Does it close an issue? Multiple? -->
Closes #

<!-- (For internal contributors): Does it relate to an issue on public
roadmap? -->
<!--
Relates to [roadmap](https://github.com/orgs/Unleash/projects/10) item:
#
-->

### Important files
<!-- PRs can contain a lot of changes, but not all changes are equally
important. Where should a reviewer start looking to get an overview of
the changes? Are any files particularly important? -->


## Discussion points
<!-- Anything about the PR you'd like to discuss before it gets merged?
Got any questions or doubts? -->

---------

Signed-off-by: andreas-unleash <andreas@getunleash.ai>
2023-04-06 17:17:46 +03:00

184 lines
5.5 KiB
TypeScript

import {
IProjectHealthUpdate,
IProjectInsert,
IProjectSettings,
IProjectStore,
} from '../../lib/types/stores/project-store';
import {
IEnvironment,
IProject,
IProjectWithCount,
ProjectMode,
} from '../../lib/types';
import NotFoundError from '../../lib/error/notfound-error';
import {
IEnvironmentProjectLink,
IProjectMembersCount,
} from 'lib/db/project-store';
export default class FakeProjectStore implements IProjectStore {
projects: IProject[] = [];
projectEnvironment: Map<string, Set<string>> = new Map();
getEnvironmentsForProject(): Promise<string[]> {
throw new Error('Method not implemented.');
}
getProjectLinksForEnvironments(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environments: string[],
): Promise<IEnvironmentProjectLink[]> {
throw new Error('Method not implemented.');
}
async addEnvironmentToProject(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
id: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environment: string,
): Promise<void> {
const environments = this.projectEnvironment.get(id) || new Set();
environments.add(environment);
this.projectEnvironment.set(id, environments);
}
async getProjectsWithCounts(): Promise<IProjectWithCount[]> {
return this.projects.map((project) => {
return { ...project, memberCount: 0, featureCount: 0 };
});
}
private createInternal(project: IProjectInsert): IProject {
const newProj: IProject = {
...project,
health: 100,
createdAt: new Date(),
mode: 'open',
defaultStickiness: 'default',
};
this.projects.push(newProj);
return newProj;
}
async create(project: IProjectInsert): Promise<IProject> {
return this.createInternal(project);
}
async delete(key: string): Promise<void> {
this.projects.splice(
this.projects.findIndex((project) => project.id === key),
1,
);
}
async deleteAll(): Promise<void> {
this.projects = [];
}
async deleteEnvironmentForProject(
id: string,
environment: string,
): Promise<void> {
const environments = this.projectEnvironment.get(id);
if (environments) {
environments.delete(environment);
this.projectEnvironment.set(id, environments);
}
}
destroy(): void {}
async count(): Promise<number> {
return this.projects.length;
}
async exists(key: string): Promise<boolean> {
return this.projects.some((project) => project.id === key);
}
async get(key: string): Promise<IProject> {
const project = this.projects.find((p) => p.id === key);
if (project) {
return project;
}
throw new NotFoundError(`Could not find project with id: ${key}`);
}
async getAll(): Promise<IProject[]> {
return this.projects;
}
// eslint-disable-next-line @typescript-eslint/no-unused-vars
async getMembersCountByProject(projectId: string): Promise<number> {
return Promise.resolve(0);
}
async hasProject(id: string): Promise<boolean> {
return this.exists(id);
}
async importProjects(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
projects: IProjectInsert[],
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environments?: IEnvironment[],
): Promise<IProject[]> {
return projects.map((project) => this.createInternal(project));
}
async update(update: IProjectInsert): Promise<void> {
await this.delete(update.id);
this.createInternal(update);
}
async updateHealth(healthUpdate: IProjectHealthUpdate): Promise<void> {
this.projects.find(
(project) => project.id === healthUpdate.id,
)!.health = healthUpdate.health;
}
getMembersCount(): Promise<IProjectMembersCount[]> {
throw new Error('Method not implemented.');
}
// eslint-disable-next-line @typescript-eslint/no-unused-vars
getProjectsByUser(userId: number): Promise<string[]> {
throw new Error('Method not implemented.');
}
addEnvironmentToProjects(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environment: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
projects: string[],
): Promise<void> {
throw new Error('Method not implemented.');
}
getMembersCountByProjectAfterDate(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
projectId: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
date: string,
): Promise<number> {
throw new Error('Method not implemented');
}
// eslint-disable-next-line @typescript-eslint/no-unused-vars
getProjectSettings(projectId: string): Promise<IProjectSettings> {
throw new Error('Method not implemented.');
}
setProjectSettings(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
projectId: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
defaultStickiness: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
mode: ProjectMode,
): Promise<void> {
throw new Error('Method not implemented.');
}
}