From 93e91f3dde2efbdcc17aefa4386e7842cb3571a7 Mon Sep 17 00:00:00 2001 From: Debadree Chatterjee Date: Fri, 24 Feb 2023 18:24:11 +0530 Subject: [PATCH] stream: fix respondWithNewView() errors when view.byteOffset != 0 Fixes: https://github.com/nodejs/node/issues/42851 Refs: https://github.com/whatwg/streams/blob/f894acdd417926a2121710803cef593e15127964/reference-implementation/lib/abstract-ops/readable-streams.js#L1756 PR-URL: https://github.com/nodejs/node/pull/46465 Reviewed-By: James M Snell Reviewed-By: Minwoo Jung --- lib/internal/webstreams/readablestream.js | 2 +- test/parallel/test-whatwg-readablestream.js | 30 +++++++++++++++++++++ 2 files changed, 31 insertions(+), 1 deletion(-) diff --git a/lib/internal/webstreams/readablestream.js b/lib/internal/webstreams/readablestream.js index 6c2445b61d5fa9..0b8b8ac1ef584d 100644 --- a/lib/internal/webstreams/readablestream.js +++ b/lib/internal/webstreams/readablestream.js @@ -2965,7 +2965,7 @@ function readableByteStreamControllerRespondWithNewView(controller, view) { if (byteOffset + bytesFilled !== viewByteOffset) throw new ERR_INVALID_ARG_VALUE.RangeError('view', view); - if (bytesFilled + viewByteOffset > byteLength) + if (bytesFilled + viewByteLength > byteLength) throw new ERR_INVALID_ARG_VALUE.RangeError('view', view); if (bufferByteLength !== viewBufferByteLength) diff --git a/test/parallel/test-whatwg-readablestream.js b/test/parallel/test-whatwg-readablestream.js index 85096286d3e613..974b7791a6d68a 100644 --- a/test/parallel/test-whatwg-readablestream.js +++ b/test/parallel/test-whatwg-readablestream.js @@ -1657,3 +1657,33 @@ class Source { reader.read(new DataView(buffer)) .then(common.mustCall()); } + +{ + const stream = new ReadableStream({ + type: 'bytes', + autoAllocateChunkSize: 128, + pull: common.mustCall((controller) => { + const view = controller.byobRequest.view; + const dest = new Uint8Array( + view.buffer, + view.byteOffset, + view.byteLength + ); + dest.fill(1); + controller.byobRequest.respondWithNewView(dest); + }), + }); + + const reader = stream.getReader({ mode: 'byob' }); + + const buffer = new ArrayBuffer(10); + const view = new Uint8Array( + buffer, + 1, + 3 + ); + + reader.read(view).then(common.mustCall(({ value }) => { + assert.deepStrictEqual(value, new Uint8Array([1, 1, 1])); + })); +}