From bc3d277469b35f5e60f66fcf302c30733e75aed0 Mon Sep 17 00:00:00 2001 From: Alfred Jonsson Date: Wed, 15 May 2024 16:11:21 +0200 Subject: [PATCH] feat: allow override for mock handlers to be a function (#1375) * feat: allow override for mock handlers to be a function * fix: has -> is --------- Co-authored-by: Alfred Jonsson --- packages/mock/src/msw/index.ts | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/packages/mock/src/msw/index.ts b/packages/mock/src/msw/index.ts index 1bd139522..6c2ed31aa 100644 --- a/packages/mock/src/msw/index.ts +++ b/packages/mock/src/msw/index.ts @@ -95,19 +95,23 @@ const generateDefinition = ( : ''; const delay = getDelay(override, !isFunction(mock) ? mock : undefined); + const isHandlerOverridden = isReturnHttpResponse && !isTextPlain; + const infoParam = isHandlerOverridden ? 'info' : ''; const handlerImplementation = ` -export const ${handlerName} = (${isReturnHttpResponse && !isTextPlain ? `overrideResponse?: ${returnType}` : ''}) => { +export const ${handlerName} = (${isHandlerOverridden ? `overrideResponse?: ${returnType} | ((${infoParam}: Parameters[1]>[0]) => ${returnType})` : ''}) => { return http.${verb}('${route}', ${ delay === false - ? '() => {' - : `async () => { + ? `(${infoParam}) => {` + : `async (${infoParam}) => { await delay(${isFunction(delay) ? `(${delay})()` : delay});` } return new HttpResponse(${ isReturnHttpResponse ? isTextPlain ? `${getResponseMockFunctionName}()` - : `JSON.stringify(overrideResponse !== undefined ? overrideResponse : ${getResponseMockFunctionName}())` + : `JSON.stringify(overrideResponse !== undefined + ? (typeof overrideResponse === "function" ? overrideResponse(${infoParam}) : overrideResponse) + : ${getResponseMockFunctionName}())` : null }, {