From 7ac4c92be8ee50f92ec76f5a29e143f97da90f92 Mon Sep 17 00:00:00 2001 From: HaidongPang Date: Thu, 7 Nov 2024 15:21:31 +0800 Subject: [PATCH] Clean up orphan ReadableStream remaining after retry (#650) --- source/core/Ky.ts | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/source/core/Ky.ts b/source/core/Ky.ts index d69c03ef..0b01d822 100644 --- a/source/core/Ky.ts +++ b/source/core/Ky.ts @@ -35,6 +35,8 @@ export class Ky { // Delay the fetch so that body method shortcuts can set the Accept header await Promise.resolve(); + // Before using ky.request, _fetch clones a new Request for retries preparation. + // If retry is not needed, close the original Request ReadableStream for memory safety. let response = await ky._fetch(); for (const hook of ky._options.hooks.afterResponse) { @@ -63,6 +65,11 @@ export class Ky { throw error; } + // Now, it can be determined that a retry is not needed, + // close the ReadableStream of the ky.request. + if (!ky.request.bodyUsed){ + await ky.request.arrayBuffer(); + } // If `onDownloadProgress` is passed, it uses the stream API internally /* istanbul ignore next */ if (ky._options.onDownloadProgress) {