From e236c5e0bb60966280b4bc8bd67fad2dfbf94bfb Mon Sep 17 00:00:00 2001 From: Victor Bury Date: Fri, 7 Jun 2024 16:05:43 +0200 Subject: [PATCH] fix(msw): if no success response apply a default 200 status --- packages/mock/src/msw/index.ts | 22 +++++++++++++++++----- 1 file changed, 17 insertions(+), 5 deletions(-) diff --git a/packages/mock/src/msw/index.ts b/packages/mock/src/msw/index.ts index b01657ca5..9e2081a6a 100644 --- a/packages/mock/src/msw/index.ts +++ b/packages/mock/src/msw/index.ts @@ -90,7 +90,9 @@ const generateDefinition = ( const isTextPlain = contentTypes.includes('text/plain'); const isReturnHttpResponse = value && value !== 'undefined'; - const getResponseMockFunctionName = `${getResponseMockFunctionNameBase}${pascal(name)}`; + const getResponseMockFunctionName = `${getResponseMockFunctionNameBase}${pascal( + name, + )}`; const handlerName = `${handlerNameBase}${pascal(name)}`; const addedSplitMockImplementations = splitMockImplementations.slice( @@ -102,15 +104,25 @@ const generateDefinition = ( : ''; const mockImplementation = isReturnHttpResponse - ? `${mockImplementations}export const ${getResponseMockFunctionName} = (${isResponseOverridable ? `overrideResponse: Partial< ${returnType} > = {}` : ''})${mockData ? '' : `: ${returnType}`} => (${value})\n\n` + ? `${mockImplementations}export const ${getResponseMockFunctionName} = (${ + isResponseOverridable + ? `overrideResponse: Partial< ${returnType} > = {}` + : '' + })${mockData ? '' : `: ${returnType}`} => (${value})\n\n` : mockImplementations; const delay = getDelay(override, !isFunction(mock) ? mock : undefined); const isHandlerOverridden = isReturnHttpResponse && !isTextPlain; const infoParam = isHandlerOverridden ? 'info' : ''; const handlerImplementation = ` -export const ${handlerName} = (${isHandlerOverridden ? `overrideResponse?: ${returnType} | ((${infoParam}: Parameters[1]>[0]) => Promise<${returnType}> | ${returnType})` : ''}) => { - return http.${verb}('${route}', ${(isReturnHttpResponse && !isTextPlain) || delay !== false ? 'async' : ''} (${infoParam}) => {${ +export const ${handlerName} = (${ + isHandlerOverridden + ? `overrideResponse?: ${returnType} | ((${infoParam}: Parameters[1]>[0]) => Promise<${returnType}> | ${returnType})` + : '' + }) => { + return http.${verb}('${route}', ${ + (isReturnHttpResponse && !isTextPlain) || delay !== false ? 'async' : '' + } (${infoParam}) => {${ delay !== false ? `await delay(${isFunction(delay) ? `(${delay})()` : delay});` : '' @@ -183,7 +195,7 @@ export const generateMSW = ( generatorVerbOptions, generatorOptions, response.definition.success, - response.types.success[0].key, + response.types.success[0]?.key ?? '200', response.imports, response.types.success, response.contentTypes,