From c69d9a94bc31bb8ee90816edd17cae6a430871a7 Mon Sep 17 00:00:00 2001 From: Exitare Date: Sun, 19 Jan 2025 09:37:13 -0800 Subject: [PATCH] chore: add default behaviour override for flag selectors. (#3252) * Update default behaviour override for flag selectors * Address code review --- .../item-template.component.html | 4 +-- .../flags-selector-modal.component.spec.ts | 27 ++++++++++++++++++- .../flags-selector-modal.component.ts | 2 +- .../flags-selector/flags-selector.model.ts | 1 + .../flags-selector/flags.service.spec.ts | 25 +++++++++++++++++ .../selectors/flags-selector/flags.service.ts | 9 +++++-- 6 files changed, 62 insertions(+), 6 deletions(-) diff --git a/libs/features/item/src/item-template/item-template.component.html b/libs/features/item/src/item-template/item-template.component.html index cc4757e9df7..1d20312196f 100644 --- a/libs/features/item/src/item-template/item-template.component.html +++ b/libs/features/item/src/item-template/item-template.component.html @@ -315,7 +315,7 @@ @@ -325,7 +325,7 @@ diff --git a/libs/shared/selectors/src/selectors/flags-selector/flags-selector-modal.component.spec.ts b/libs/shared/selectors/src/selectors/flags-selector/flags-selector-modal.component.spec.ts index 6f351aa5f44..3014dd74072 100644 --- a/libs/shared/selectors/src/selectors/flags-selector/flags-selector-modal.component.spec.ts +++ b/libs/shared/selectors/src/selectors/flags-selector/flags-selector-modal.component.spec.ts @@ -54,7 +54,32 @@ describe('FlagsSelectorModalComponent', () => { expect(component.flagValues).toEqual([true, true, true]); expect(spyGetValueFromBits).toHaveBeenCalledTimes(1); - expect(spyGetValueFromBits).toHaveBeenCalledWith([true, true, true]); + expect(spyGetValueFromBits).toHaveBeenCalledWith([true, true, true], false); expect(component.value).toEqual(value); }); + + it('toggleBit() override should properly work', () => { + const value = 123456; + const overrideDefaultBehavior = true; + const flags = [{ bit: 1, name: 'flag-1' }]; + const initialFlagValues = [true, false, true]; + const updatedValue = 654321; + + // Set up the component's initial state + component.value = value; + component.config = { name: 'Mock Modal Name', flags, overrideDefaultBehavior }; + component.flagValues = [...initialFlagValues]; + + // Spy on the flagsService.getValueFromBits method + const spyGetValueFromBits = spyOn(flagsService, 'getValueFromBits').and.returnValue(updatedValue); + + // Act: Call toggleBit with a specific bit index + component.toggleBit(1); // Toggle the second bit (index 1) + + // Assertions + expect(component.flagValues).toEqual([true, true, true]); // Bit at index 1 should toggle to `true` + expect(spyGetValueFromBits).toHaveBeenCalledTimes(1); + expect(spyGetValueFromBits).toHaveBeenCalledWith([true, true, true], overrideDefaultBehavior); + expect(component.value).toEqual(updatedValue); // Value should update based on the override behavior + }); }); diff --git a/libs/shared/selectors/src/selectors/flags-selector/flags-selector-modal.component.ts b/libs/shared/selectors/src/selectors/flags-selector/flags-selector-modal.component.ts index 8170c4c9d11..cea31d30492 100644 --- a/libs/shared/selectors/src/selectors/flags-selector/flags-selector-modal.component.ts +++ b/libs/shared/selectors/src/selectors/flags-selector/flags-selector-modal.component.ts @@ -28,6 +28,6 @@ export class FlagsSelectorModalComponent extends BaseSelectorModalComponent { expect(service.getBitsArray(flags, value)).toEqual(mockResult); expect(getBitsFromValueSpy).toHaveBeenCalledWith(value, flags[0].bit + 1); }); + + it('should handle value -1 (all bits not set)', () => { + const service = TestBed.inject(FlagsService); + expect(service.getBitsFromValue(-1, 5)).toEqual([false, false, false, false, false]); + }); + + it('should handle value 0 (all bits unset)', () => { + const service = TestBed.inject(FlagsService); + expect(service.getBitsFromValue(0, 3)).toEqual([false, false, false]); + }); + + it('should handle count 0 (empty bits array)', () => { + const service = TestBed.inject(FlagsService); + expect(service.getBitsFromValue(5, 0)).toEqual([]); + }); + + it('should return -1 when overrideDefaultBehavior is true and all bits are false', () => { + const service = TestBed.inject(FlagsService); + expect(service.getValueFromBits([false, false, false], true)).toEqual(-1); + }); + + it('should return 0 when overrideDefaultBehavior is false and all bits are false', () => { + const service = TestBed.inject(FlagsService); + expect(service.getValueFromBits([false, false, false], false)).toEqual(0); + }); }); diff --git a/libs/shared/selectors/src/selectors/flags-selector/flags.service.ts b/libs/shared/selectors/src/selectors/flags-selector/flags.service.ts index 10a9c429e3d..0f6722b3a80 100644 --- a/libs/shared/selectors/src/selectors/flags-selector/flags.service.ts +++ b/libs/shared/selectors/src/selectors/flags-selector/flags.service.ts @@ -7,7 +7,7 @@ import { Flag } from '@keira/shared/constants'; export class FlagsService { getBitsFromValue(value: number, bitsCount: number): boolean[] { const bits = new Array(bitsCount); - const binaryStr: string = value.toString(2).split('').reverse().join(''); + const binaryStr: string = value !== -1 ? value.toString(2).split('').reverse().join('') : '0'.repeat(bitsCount); for (let i = 0; i < bitsCount; i++) { bits[i] = parseInt(binaryStr[i], 10) === 1; @@ -16,7 +16,12 @@ export class FlagsService { return bits; } - getValueFromBits(bits: boolean[]): number { + getValueFromBits(bits: boolean[], overrideDefaultBehavior: boolean = false): number { + // override default behavior if all bits are false + if (overrideDefaultBehavior && bits.every((bit) => !bit)) { + return -1; + } + let result = 0; for (let i = 0; i < bits.length; i++) {