1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00

fix: simplify how we update projects

This commit is contained in:
Ivar Conradi Østhus 2021-10-21 21:06:56 +02:00
parent f0dfe204ee
commit 1924961efa
No known key found for this signature in database
GPG Key ID: 31AC596886B0BD09
3 changed files with 20 additions and 24 deletions

View File

@ -13,6 +13,7 @@ import {
FEATURE_ENVIRONMENT_DISABLED,
FEATURE_ENVIRONMENT_ENABLED,
FEATURE_METADATA_UPDATED,
FEATURE_PROJECT_CHANGE,
FEATURE_REVIVED,
FEATURE_STALE_OFF,
FEATURE_STALE_ON,
@ -723,34 +724,30 @@ class FeatureToggleServiceV2 {
return { ...legacyFeature, enabled, strategies };
}
// @deprecated
// TODO: move to projectService
async updateField(
async changeProject(
featureName: string,
field: string,
// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
value: any,
newProject: string,
userName: string,
event: string,
): Promise<any> {
): Promise<void> {
const feature = await this.featureToggleStore.get(featureName);
feature[field] = value;
await this.featureToggleStore.update(feature.project, feature);
const oldProject = feature.project;
feature.project = newProject;
await this.featureToggleStore.update(newProject, feature);
const tags = await this.featureTagStore.getAllTagsForFeature(
featureName,
);
// Workaround to support pre 4.1 format
const data = await this.getFeatureToggleLegacy(featureName);
await this.eventStore.store({
type: event,
type: FEATURE_PROJECT_CHANGE,
createdBy: userName,
data,
project: data.project,
data: {
name: feature.name,
oldProject,
newProject,
},
project: newProject,
tags,
});
return feature;
}
async getArchivedFeatures(): Promise<FeatureToggle[]> {

View File

@ -6,7 +6,6 @@ import { nameType } from '../routes/util';
import { projectSchema } from './project-schema';
import NotFoundError from '../error/notfound-error';
import {
FEATURE_PROJECT_CHANGE,
PROJECT_CREATED,
PROJECT_DELETED,
PROJECT_UPDATED,
@ -222,12 +221,10 @@ export default class ProjectService {
if (!isCompatibleWithTargetProject) {
throw new IncompatibleProjectError(newProjectId);
}
const updatedFeature = await this.featureToggleService.updateField(
const updatedFeature = await this.featureToggleService.changeProject(
featureName,
'project',
newProjectId,
user.username,
FEATURE_PROJECT_CHANGE,
);
await this.featureToggleService.updateFeatureStrategyProject(
featureName,

View File

@ -17,7 +17,7 @@ let db: ITestDb;
let projectService;
let accessService;
let featureToggleService;
let featureToggleService: FeatureToggleServiceV2;
let user;
beforeAll(async () => {
@ -511,13 +511,15 @@ test('should change project when checks pass', async () => {
await projectService.createProject(projectDestination, user);
await featureToggleService.createFeatureToggle(project.id, toggle, user);
const updatedFeature = await projectService.changeProject(
await projectService.changeProject(
projectDestination.id,
toggle.name,
user,
project.id,
);
const updatedFeature = await featureToggleService.getFeature(toggle.name);
expect(updatedFeature.project).toBe(projectDestination.id);
});