From 518d195f8c806a2a7457ef81bf7d77e3e291a8fb Mon Sep 17 00:00:00 2001 From: Artem Zakharchenko Date: Sat, 4 Nov 2023 15:11:04 +0100 Subject: [PATCH] fix(Safari): send explicit null response bodies --- .../start/createRequestListener.ts | 22 ++++++++++++++----- 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/src/browser/setupWorker/start/createRequestListener.ts b/src/browser/setupWorker/start/createRequestListener.ts index 415094b36..494f31fa1 100644 --- a/src/browser/setupWorker/start/createRequestListener.ts +++ b/src/browser/setupWorker/start/createRequestListener.ts @@ -54,21 +54,31 @@ export const createRequestListener = ( * Check that the browser supports that before sending it to the worker. */ if (context.supports.readableStreamTransfer) { - const responseStream = response.body + const responseStreamOrNull = response.body + messageChannel.postMessage( 'MOCK_RESPONSE', { ...responseInit, - body: responseStream, + body: responseStreamOrNull, }, - responseStream ? [responseStream] : undefined, + responseStreamOrNull ? [responseStreamOrNull] : undefined, ) } else { - // As a fallback, send the response body buffer to the worker. - const responseBuffer = await responseClone.arrayBuffer() + /** + * @note If we are here, this means the current environment doesn't + * support "ReadableStream" as transferable. In that case, + * attempt to read the non-empty response body as ArrayBuffer, if it's not empty. + * @see https://github.com/mswjs/msw/issues/1827 + */ + const responseBufferOrNull = + response.body === null + ? null + : await responseClone.arrayBuffer() + messageChannel.postMessage('MOCK_RESPONSE', { ...responseInit, - body: responseBuffer, + body: responseBufferOrNull, }) }