From 84e99c3ab72ce34bd282d9d53c180a739f38aa86 Mon Sep 17 00:00:00 2001 From: timdeschryver <28659384+timdeschryver@users.noreply.github.com> Date: Mon, 18 Nov 2019 20:05:34 +0100 Subject: [PATCH] feat(store): add clearResult to reset a mock selector BREAKING CHANGE: BEFORE: Using `mockSelector.setResult(undefined)` resulted in clearing the return value. AFTER: Using `mockSelector.setResult(undefined)` will set the return value of the selector to `undefined`. To reset the mock selector, use `mockSelector.clearResult()`. --- modules/store/src/selector.ts | 14 +++++++++++--- modules/store/testing/src/mock_store.ts | 2 +- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/modules/store/src/selector.ts b/modules/store/src/selector.ts index db444b395b..0ac50d9001 100644 --- a/modules/store/src/selector.ts +++ b/modules/store/src/selector.ts @@ -7,6 +7,7 @@ export type MemoizedProjection = { memoized: AnyFn; reset: () => void; setResult: (result?: any) => void; + clearResult: () => void; }; export type MemoizeFn = (t: AnyFn) => MemoizedProjection; @@ -23,6 +24,7 @@ export interface MemoizedSelector< release(): void; projector: ProjectorFn; setResult: (result?: Result) => void; + clearResult: () => void; } export interface MemoizedSelectorWithProps< @@ -34,6 +36,7 @@ export interface MemoizedSelectorWithProps< release(): void; projector: ProjectorFn; setResult: (result?: Result) => void; + clearResult: () => void; } export function isEqualCheck(a: any, b: any): boolean { @@ -76,13 +79,17 @@ export function defaultMemoize( } function setResult(result: any = undefined) { - overrideResult = result; + overrideResult = { result }; + } + + function clearResult() { + overrideResult = undefined; } // tslint:disable-next-line:no-any anything could be the result. function memoized(): any { if (overrideResult !== undefined) { - return overrideResult; + return overrideResult.result; } if (!lastArguments) { @@ -107,7 +114,7 @@ export function defaultMemoize( return newResult; } - return { memoized, reset, setResult }; + return { memoized, reset, setResult, clearResult }; } export function createSelector( @@ -590,6 +597,7 @@ export function createSelectorFactory( release, projector: memoizedProjector.memoized, setResult: memoizedState.setResult, + clearResult: memoizedState.clearResult, }); }; } diff --git a/modules/store/testing/src/mock_store.ts b/modules/store/testing/src/mock_store.ts index 7a3eb0a249..e3860cb98f 100644 --- a/modules/store/testing/src/mock_store.ts +++ b/modules/store/testing/src/mock_store.ts @@ -102,7 +102,7 @@ export class MockStore extends Store { MockStore.selectors.forEach((_, selector) => { if (typeof selector !== 'string') { selector.release(); - selector.setResult(); + selector.clearResult(); } });