From 42bcd5b9364c08a50bc88a97e480490fe6d0e624 Mon Sep 17 00:00:00 2001 From: ealush Date: Wed, 7 Aug 2024 01:14:22 +0300 Subject: [PATCH] Lazy Draft works --- packages/vest/src/isolates/omitWhen.ts | 7 ++--- packages/vest/src/isolates/skipWhen.ts | 7 ++--- .../src/suiteResult/selectors/LazyDraft.ts | 24 +++++++++++++++++ packages/vest/src/suiteResult/suiteResult.ts | 27 ++++++++++++------- packages/vest/tsconfig.json | 1 + vitest.config.ts | 10 ++++++- 6 files changed, 56 insertions(+), 20 deletions(-) create mode 100644 packages/vest/src/suiteResult/selectors/LazyDraft.ts diff --git a/packages/vest/src/isolates/omitWhen.ts b/packages/vest/src/isolates/omitWhen.ts index f99cfa7b3..61ea0b145 100644 --- a/packages/vest/src/isolates/omitWhen.ts +++ b/packages/vest/src/isolates/omitWhen.ts @@ -2,11 +2,11 @@ import type { CB } from 'vest-utils'; import { optionalFunctionValue } from 'vest-utils'; import { Isolate } from 'vestjs-runtime'; +import { LazyDraft } from 'LazyDraft'; import { SuiteContext, useOmitted } from 'SuiteContext'; import { TFieldName, TGroupName } from 'SuiteResultTypes'; import { VestIsolateType } from 'VestIsolateType'; import { TDraftCondition } from 'getTypedMethods'; -import { useCreateSuiteResult } from 'suiteResult'; /** * Conditionally omits tests from the suite. @@ -27,10 +27,7 @@ export function omitWhen( { omitted: useWithinActiveOmitWhen() || - optionalFunctionValue( - conditional, - optionalFunctionValue(useCreateSuiteResult), - ), + optionalFunctionValue(conditional, LazyDraft()), }, callback, ); diff --git a/packages/vest/src/isolates/skipWhen.ts b/packages/vest/src/isolates/skipWhen.ts index 37ff4cd18..53dd27750 100644 --- a/packages/vest/src/isolates/skipWhen.ts +++ b/packages/vest/src/isolates/skipWhen.ts @@ -1,11 +1,11 @@ import { CB, optionalFunctionValue } from 'vest-utils'; import { Isolate } from 'vestjs-runtime'; +import { LazyDraft } from 'LazyDraft'; import { SuiteContext, useSkipped } from 'SuiteContext'; import { TFieldName, TGroupName } from 'SuiteResultTypes'; import { VestIsolateType } from 'VestIsolateType'; import { TDraftCondition } from 'getTypedMethods'; -import { useCreateSuiteResult } from 'suiteResult'; /** * Conditionally skips running tests within the callback. @@ -29,10 +29,7 @@ export function skipWhen( // we should skip the test if the parent conditional is true. useIsExcludedIndividually() || // Otherwise, we should skip the test if the conditional is true. - optionalFunctionValue( - condition, - optionalFunctionValue(useCreateSuiteResult), - ), + optionalFunctionValue(condition, LazyDraft()), }, callback, ); diff --git a/packages/vest/src/suiteResult/selectors/LazyDraft.ts b/packages/vest/src/suiteResult/selectors/LazyDraft.ts new file mode 100644 index 000000000..8426c77c7 --- /dev/null +++ b/packages/vest/src/suiteResult/selectors/LazyDraft.ts @@ -0,0 +1,24 @@ +import { + SuiteResult, + SuiteSummary, + TFieldName, + TGroupName, +} from 'SuiteResultTypes'; +import { constructSuiteResultObject, useCreateSuiteResult } from 'suiteResult'; + +// @vx-allow use-use +export function LazyDraft< + F extends TFieldName, + G extends TGroupName, +>(): SuiteResult { + const emptySummary = constructSuiteResultObject(new SuiteSummary()); + + return new Proxy(emptySummary, { + get: (_, prop) => { + // @vx-allow use-use + const result = useCreateSuiteResult(); + + return result[prop as keyof SuiteResult]; + }, + }) as SuiteResult; +} diff --git a/packages/vest/src/suiteResult/suiteResult.ts b/packages/vest/src/suiteResult/suiteResult.ts index 76086110d..897675254 100644 --- a/packages/vest/src/suiteResult/suiteResult.ts +++ b/packages/vest/src/suiteResult/suiteResult.ts @@ -1,7 +1,12 @@ -import { freezeAssign } from 'vest-utils'; +import { assign, Maybe } from 'vest-utils'; import { useSuiteName, useSuiteResultCache } from 'Runtime'; -import { SuiteResult, TFieldName, TGroupName } from 'SuiteResultTypes'; +import { + SuiteResult, + SuiteSummary, + TFieldName, + TGroupName, +} from 'SuiteResultTypes'; import { suiteSelectors } from 'suiteSelectors'; import { useProduceSuiteSummary } from 'useProduceSuiteSummary'; @@ -15,12 +20,16 @@ export function useCreateSuiteResult< // @vx-allow use-use const suiteName = useSuiteName(); - return freezeAssign>( - summary, - suiteSelectors(summary), - { - suiteName, - }, - ) as SuiteResult; + + return Object.freeze(constructSuiteResultObject(summary, suiteName)); }); } + +export function constructSuiteResultObject< + F extends TFieldName, + G extends TGroupName, +>(summary: SuiteSummary, suiteName?: Maybe): SuiteResult { + return assign(summary, suiteSelectors(summary), { + suiteName, + }) as SuiteResult; +} diff --git a/packages/vest/tsconfig.json b/packages/vest/tsconfig.json index 8feccd6d6..7c311562d 100644 --- a/packages/vest/tsconfig.json +++ b/packages/vest/tsconfig.json @@ -30,6 +30,7 @@ "./src/suiteResult/selectors/hasFailuresByTestObjects.ts" ], "collectFailures": ["./src/suiteResult/selectors/collectFailures.ts"], + "LazyDraft": ["./src/suiteResult/selectors/LazyDraft.ts"], "shouldSkipDoneRegistration": [ "./src/suiteResult/done/shouldSkipDoneRegistration.ts" ], diff --git a/vitest.config.ts b/vitest.config.ts index 736555f2b..4ad47d879 100644 --- a/vitest.config.ts +++ b/vitest.config.ts @@ -11,7 +11,15 @@ export default defineConfig({ plugins: [ tsconfigPaths({ loose: true, - projects: ["packages/vest-utils","packages/context","packages/vestjs-runtime","packages/vast","packages/n4s","packages/vest","packages/anyone"], + projects: [ + 'packages/vest-utils', + 'packages/context', + 'packages/vestjs-runtime', + 'packages/vast', + 'packages/n4s', + 'packages/vest', + 'packages/anyone', + ], }), ], });