From 7e221ae24ecb9b23f175c929fe0acf6b89332a2b Mon Sep 17 00:00:00 2001 From: Omar El-Mihilmy Date: Wed, 3 Nov 2021 12:22:59 -0700 Subject: [PATCH] fs: nullish coalescing to respect zero positional reads MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit When the file read position is moved passing zero is not respected and `null` is used instead. PR fixes the issues by using nullish coalescing which will return the rhs only when the lhs is `null` or `undefined`; respecting the zero. Fixes: https://github.com/nodejs/node/issues/40715 PR-URL: https://github.com/nodejs/node/pull/40716 Fixes: https://github.com/nodejs/node/issues/40699 Reviewed-By: Robert Nagy Reviewed-By: Luigi Pinca Reviewed-By: Ruben Bridgewater Reviewed-By: Tobias Nießen Reviewed-By: Evan Lucas --- lib/internal/fs/promises.js | 2 +- .../test-fs-promises-file-handle-read.js | 20 +++++++++++++++++++ 2 files changed, 21 insertions(+), 1 deletion(-) diff --git a/lib/internal/fs/promises.js b/lib/internal/fs/promises.js index 85ff23bff0c96e..2698613fb22f43 100644 --- a/lib/internal/fs/promises.js +++ b/lib/internal/fs/promises.js @@ -469,7 +469,7 @@ async function read(handle, bufferOrOptions, offset, length, position) { } offset = bufferOrOptions.offset || 0; length = buffer.byteLength; - position = bufferOrOptions.position || null; + position = bufferOrOptions.position ?? null; } if (offset == null) { diff --git a/test/parallel/test-fs-promises-file-handle-read.js b/test/parallel/test-fs-promises-file-handle-read.js index 44ef2c6b815a3d..b79d65e9484a1f 100644 --- a/test/parallel/test-fs-promises-file-handle-read.js +++ b/test/parallel/test-fs-promises-file-handle-read.js @@ -68,6 +68,25 @@ async function validateReadNoParams() { await fileHandle.read(); } +// Validates that the zero position is respected after the position has been +// moved. The test iterates over the xyz chars twice making sure that the values +// are read from the correct position. +async function validateReadWithPositionZero() { + const opts = { useConf: true }; + const filePath = fixtures.path('x.txt'); + const fileHandle = await open(filePath, 'r'); + const expectedSequence = ['x', 'y', 'z']; + + for (let i = 0; i < expectedSequence.length * 2; i++) { + const len = 1; + const pos = i % 3; + const buf = Buffer.alloc(len); + const { bytesRead } = await read(fileHandle, buf, 0, len, pos, opts); + assert.strictEqual(bytesRead, len); + assert.strictEqual(buf.toString(), expectedSequence[pos]); + } +} + (async function() { tmpdir.refresh(); @@ -78,4 +97,5 @@ async function validateReadNoParams() { await validateLargeRead({ useConf: false }); await validateLargeRead({ useConf: true }); await validateReadNoParams(); + await validateReadWithPositionZero(); })().then(common.mustCall());