mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-25 00:07:47 +01:00
fix: handle title diffing correctly in strategy change diffs (#5971)
A strategy title can be either an empty string or undefined on the type we use in the frontend. In the snapshot it can be an empty string, null (presumably), and undefined. This change updates the diffing logic to handle the various title diff cases correctly. It also updates the type used for the snapshot to reflect this.
This commit is contained in:
parent
5253482f61
commit
01a38becb3
@ -1,5 +1,6 @@
|
||||
import { IChangeRequestUpdateStrategy } from 'component/changeRequest/changeRequest.types';
|
||||
import { IFeatureStrategy } from 'interfaces/strategy';
|
||||
import omit from 'lodash.omit';
|
||||
import { getChangesThatWouldBeOverwritten } from './strategy-change-diff-calculation';
|
||||
|
||||
describe('Strategy change conflict detection', () => {
|
||||
@ -287,4 +288,59 @@ describe('Strategy change conflict detection', () => {
|
||||
|
||||
expect(result).toBeNull();
|
||||
});
|
||||
|
||||
test('It treats `null` and `""` for `title` in the change as equal to `""` in the existing strategy', () => {
|
||||
const emptyTitleExistingStrategy = {
|
||||
...existingStrategy,
|
||||
title: '',
|
||||
};
|
||||
const undefinedTitleExistingStrategy = omit(existingStrategy, 'title');
|
||||
|
||||
const { title: _snapshotTitle, ...snapshot } = change.payload.snapshot!;
|
||||
|
||||
const nullTitleInSnapshot = {
|
||||
...change,
|
||||
payload: {
|
||||
...change.payload,
|
||||
snapshot: {
|
||||
...snapshot,
|
||||
title: null,
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
const emptyTitleInSnapshot = {
|
||||
...change,
|
||||
payload: {
|
||||
...change.payload,
|
||||
snapshot: {
|
||||
...snapshot,
|
||||
title: '',
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
const missingTitleInSnapshot = {
|
||||
...change,
|
||||
payload: {
|
||||
...change.payload,
|
||||
snapshot,
|
||||
},
|
||||
};
|
||||
|
||||
const cases = [
|
||||
undefinedTitleExistingStrategy,
|
||||
emptyTitleExistingStrategy,
|
||||
].flatMap((existing) =>
|
||||
[
|
||||
nullTitleInSnapshot,
|
||||
emptyTitleInSnapshot,
|
||||
missingTitleInSnapshot,
|
||||
].map((changeValue) =>
|
||||
getChangesThatWouldBeOverwritten(existing, changeValue),
|
||||
),
|
||||
);
|
||||
|
||||
expect(cases.every((result) => result === null)).toBeTruthy();
|
||||
});
|
||||
});
|
||||
|
@ -55,6 +55,16 @@ export const getChangesThatWouldBeOverwritten = (
|
||||
newValue: snapshotValue,
|
||||
};
|
||||
}
|
||||
} else if (key === 'title') {
|
||||
// the title can be defined as `null` or
|
||||
// `undefined`, so we fallback to an empty string
|
||||
if (hasJsonDiff(snapshotValue ?? '', currentValue ?? '')) {
|
||||
return {
|
||||
property: key as keyof IFeatureStrategy,
|
||||
oldValue: currentValue,
|
||||
newValue: snapshotValue,
|
||||
};
|
||||
}
|
||||
} else if (hasChanged(snapshotValue, currentValue)) {
|
||||
return {
|
||||
property: key as keyof IFeatureStrategy,
|
||||
|
@ -228,7 +228,7 @@ export type ChangeRequestAddStrategy = Pick<
|
||||
|
||||
export type ChangeRequestEditStrategy = ChangeRequestAddStrategy & {
|
||||
id: string;
|
||||
snapshot?: IFeatureStrategy;
|
||||
snapshot?: Omit<IFeatureStrategy, 'title'> & { title?: string | null };
|
||||
};
|
||||
|
||||
type ChangeRequestDeleteStrategy = {
|
||||
|
Loading…
Reference in New Issue
Block a user