From 83a0fb3576e0e0eb21bd82b752007d03c13eeefa Mon Sep 17 00:00:00 2001 From: Matteo Collina Date: Thu, 11 Apr 2024 20:52:33 +0200 Subject: [PATCH] Skip the creation of a transform stream in fetch (#3093) --- lib/web/fetch/index.js | 21 ++++++++++----------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/lib/web/fetch/index.js b/lib/web/fetch/index.js index 58d61585c06..30f457df395 100644 --- a/lib/web/fetch/index.js +++ b/lib/web/fetch/index.js @@ -1080,23 +1080,17 @@ function fetchFinale (fetchParams, response) { if (internalResponse.body == null) { processResponseEndOfBody() } else { + // mcollina: all the following steps of the specs are skipped. + // The internal transform stream is not needed. + // // 1. Let transformStream be a new TransformStream. // 2. Let identityTransformAlgorithm be an algorithm which, given chunk, enqueues chunk in transformStream. // 3. Set up transformStream with transformAlgorithm set to identityTransformAlgorithm and flushAlgorithm // set to processResponseEndOfBody. - const transformStream = new TransformStream({ - start () { }, - transform (chunk, controller) { - controller.enqueue(chunk) - }, - flush: processResponseEndOfBody - }) - // 4. Set internalResponse’s body’s stream to the result of internalResponse’s body’s stream piped through transformStream. - internalResponse.body.stream.pipeThrough(transformStream) const byteStream = new ReadableStream({ - readableStream: transformStream.readable, + readableStream: internalResponse.body.stream, async start () { this._bodyReader = this.readableStream.getReader() }, @@ -1105,7 +1099,12 @@ function fetchFinale (fetchParams, response) { const { done, value } = await this._bodyReader.read() if (done) { - queueMicrotask(() => readableStreamClose(controller)) + queueMicrotask(() => { + readableStreamClose(controller) + + // Added to in lieu of steps 1-4 of the spec + processResponseEndOfBody() + }) break }