1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-02-04 00:18:01 +01:00
unleash.unleash/src/test/fixtures/fake-feature-environment-store.ts
Christopher Kolstad 53354224fc
chore: Bump biome and configure husky (#6589)
Upgrades biome to 1.6.1, and updates husky pre-commit hook.

Most changes here are making type imports explicit.
2024-03-18 13:58:05 +01:00

245 lines
7.4 KiB
TypeScript

import type {
FeatureEnvironmentKey,
IFeatureEnvironmentStore,
} from '../../lib/types/stores/feature-environment-store';
import type { IFeatureEnvironment, IVariant } from '../../lib/types/model';
import NotFoundError from '../../lib/error/notfound-error';
export default class FakeFeatureEnvironmentStore
implements IFeatureEnvironmentStore
{
featureEnvironments: IFeatureEnvironment[] = [];
async addEnvironmentToFeature(
featureName: string,
environment: string,
enabled: boolean,
): Promise<void> {
this.featureEnvironments.push({ environment, enabled, featureName });
}
async addVariantsToFeatureEnvironment(
featureName: string,
environment: string,
variants: IVariant[],
): Promise<void> {
this.setVariantsToFeatureEnvironments(
featureName,
[environment],
variants,
);
}
async setVariantsToFeatureEnvironments(
featureName: string,
environments: string[],
variants: IVariant[],
): Promise<void> {
this.featureEnvironments
.filter(
(fe) =>
fe.featureName === featureName &&
environments.includes(fe.environment),
)
.forEach((fe) => {
fe.variants = variants;
});
}
async delete(key: FeatureEnvironmentKey): Promise<void> {
this.featureEnvironments.splice(
this.featureEnvironments.findIndex(
(fE) =>
fE.environment === key.environment &&
fE.featureName === key.featureName,
),
1,
);
}
async deleteAll(): Promise<void> {
this.featureEnvironments = [];
}
destroy(): void {}
async disconnectFeatures(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environment: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
project: string,
): Promise<void> {
return Promise.resolve(undefined);
}
async exists(key: FeatureEnvironmentKey): Promise<boolean> {
return this.featureEnvironments.some(
(fE) =>
fE.featureName === key.featureName &&
fE.environment === key.environment,
);
}
async featureHasEnvironment(
environment: string,
featureName: string,
): Promise<boolean> {
return this.exists({ environment, featureName });
}
async get(key: FeatureEnvironmentKey): Promise<IFeatureEnvironment> {
const featureEnvironment = this.featureEnvironments.find(
(fE) =>
fE.environment === key.environment &&
fE.featureName === key.featureName,
);
if (featureEnvironment) {
return featureEnvironment;
}
throw new NotFoundError(
`Could not find environment ${key.environment} for feature: ${key.featureName}`,
);
}
async getAll(): Promise<IFeatureEnvironment[]> {
return this.featureEnvironments;
}
getEnvironmentMetaData(
environment: string,
featureName: string,
): Promise<IFeatureEnvironment> {
return this.get({ environment, featureName });
}
async isEnvironmentEnabled(
featureName: string,
environment: string,
): Promise<boolean> {
try {
const fE = await this.get({ featureName, environment });
return fE.enabled;
} catch (e) {
return false;
}
}
async removeEnvironmentForFeature(
featureName: string,
environment: string,
): Promise<void> {
return this.delete({ featureName, environment });
}
async setEnvironmentEnabledStatus(
environment: string,
featureName: string,
enabled: boolean,
): Promise<number> {
const fE = await this.get({ environment, featureName });
if (fE.enabled !== enabled) {
fE.enabled = enabled;
return 1;
} else {
return 0;
}
}
async connectProject(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environment: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
projectId: string,
): Promise<void> {
return Promise.resolve(undefined);
}
async connectFeatures(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environment: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
projectId: string,
): Promise<void> {
return Promise.reject(new Error('Not implemented'));
}
async disconnectProject(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environment: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
projectId: string,
): Promise<void> {
return Promise.reject(new Error('Not implemented'));
}
async connectFeatureToEnvironmentsForProject(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
featureName: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
projectId: string,
): Promise<void> {
return Promise.resolve();
}
disableEnvironmentIfNoStrategies(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
featureName: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environment: string,
): Promise<void> {
return Promise.reject(new Error('Not implemented'));
}
copyEnvironmentFeaturesByProjects(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
sourceEnvironment: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
destinationEnvironment: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
projects: string[],
): Promise<void> {
throw new Error('Method not implemented.');
}
cloneStrategies(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
sourceEnvironment: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
destinationEnvironment: string,
): Promise<void> {
throw new Error('Method not implemented.');
}
async addFeatureEnvironment(
featureEnvironment: IFeatureEnvironment,
): Promise<void> {
this.featureEnvironments.push(featureEnvironment);
return Promise.resolve();
}
getEnvironmentsForFeature(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
featureName: string,
): Promise<IFeatureEnvironment[]> {
throw new Error('Method not implemented.');
}
clonePreviousVariants(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environment: string,
// eslint-disable-next-line @typescript-eslint/no-unused-vars
project: string,
): Promise<void> {
throw new Error('Method not implemented.');
}
getAllByFeatures(
// eslint-disable-next-line @typescript-eslint/no-unused-vars
features: string[],
// eslint-disable-next-line @typescript-eslint/no-unused-vars
environment?: string,
): Promise<IFeatureEnvironment[]> {
throw new Error('Method not implemented.');
}
}