From ea1cc7307b74d0990e7f06d7b61268f95599b598 Mon Sep 17 00:00:00 2001 From: Nikola Glavina Date: Sat, 14 Nov 2020 01:53:49 +0100 Subject: [PATCH 1/2] fs: rebased & updated --- lib/internal/fs/promises.js | 11 ++++++- .../test-fs-promises-file-handle-read.js | 29 ++++++++++++++----- 2 files changed, 31 insertions(+), 9 deletions(-) diff --git a/lib/internal/fs/promises.js b/lib/internal/fs/promises.js index 90b55ff9e592d1..0b5d409e3e79c5 100644 --- a/lib/internal/fs/promises.js +++ b/lib/internal/fs/promises.js @@ -346,7 +346,16 @@ async function open(path, flags, mode) { flagsNumber, mode, kUsePromises)); } -async function read(handle, buffer, offset, length, position) { +async function read(handle, bufferOrOptions, offset, length, position) { + let buffer = bufferOrOptions; + + if (!isArrayBufferView(buffer)) { + buffer = bufferOrOptions.buffer || Buffer.alloc(16384); + offset = bufferOrOptions.offset || 0; + length = buffer.length; + position = bufferOrOptions.position || null; + } + validateBuffer(buffer); 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 5ba7fc63e3f44d..44c35840f283ed 100644 --- a/test/parallel/test-fs-promises-file-handle-read.js +++ b/test/parallel/test-fs-promises-file-handle-read.js @@ -13,7 +13,11 @@ const tmpdir = require('../common/tmpdir'); const assert = require('assert'); const tmpDir = tmpdir.path; -tmpdir.refresh(); +async function read(fileHandle, buffer, offset, length, position) { + return useConf ? + fileHandle.read({ buffer, offset, length, position }) : + fileHandle.read(buffer, offset, length, position); +} async function validateRead() { const filePath = path.resolve(tmpDir, 'tmp-read-file.txt'); @@ -23,7 +27,7 @@ async function validateRead() { const fd = fs.openSync(filePath, 'w+'); fs.writeSync(fd, buffer, 0, buffer.length); fs.closeSync(fd); - const readAsyncHandle = await fileHandle.read(Buffer.alloc(11), 0, 11, 0); + const readAsyncHandle = await read(fileHandle, Buffer.alloc(11), 0, 11, 0); assert.deepStrictEqual(buffer.length, readAsyncHandle.bytesRead); assert.deepStrictEqual(buffer, readAsyncHandle.buffer); @@ -38,7 +42,7 @@ async function validateEmptyRead() { const fd = fs.openSync(filePath, 'w+'); fs.writeSync(fd, buffer, 0, buffer.length); fs.closeSync(fd); - const readAsyncHandle = await fileHandle.read(Buffer.alloc(11), 0, 11, 0); + const readAsyncHandle = await read(fileHandle, Buffer.alloc(11), 0, 11, 0); assert.deepStrictEqual(buffer.length, readAsyncHandle.bytesRead); await fileHandle.close(); @@ -51,12 +55,21 @@ async function validateLargeRead() { const filePath = fixtures.path('x.txt'); const fileHandle = await open(filePath, 'r'); const pos = 0xffffffff + 1; // max-uint32 + 1 - const readHandle = await fileHandle.read(Buffer.alloc(1), 0, 1, pos); + const readHandle = await read(fileHandle, Buffer.alloc(1), 0, 1, pos); assert.strictEqual(readHandle.bytesRead, 0); } -validateRead() - .then(validateEmptyRead) - .then(validateLargeRead) - .then(common.mustCall()); +let useConf = false; + +(async function() { + for (const value of [false, true]) { + tmpdir.refresh(); + useConf = value; + + await validateRead() + .then(validateEmptyRead) + .then(validateLargeRead) + .then(common.mustCall()); + } +}); From 15402e8a52d57f80c26bc2c07d936443b47290cf Mon Sep 17 00:00:00 2001 From: Nikola Glavina Date: Sat, 14 Nov 2020 12:31:18 +0100 Subject: [PATCH 2/2] fs: merge changes from aduh95 --- lib/internal/fs/promises.js | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/lib/internal/fs/promises.js b/lib/internal/fs/promises.js index 0b5d409e3e79c5..bdd038b18cd6e5 100644 --- a/lib/internal/fs/promises.js +++ b/lib/internal/fs/promises.js @@ -348,16 +348,18 @@ async function open(path, flags, mode) { async function read(handle, bufferOrOptions, offset, length, position) { let buffer = bufferOrOptions; - if (!isArrayBufferView(buffer)) { - buffer = bufferOrOptions.buffer || Buffer.alloc(16384); + if (bufferOrOptions.buffer) { + buffer = bufferOrOptions.buffer; + validateBuffer(buffer); + } else { + buffer = Buffer.alloc(16384); + } offset = bufferOrOptions.offset || 0; length = buffer.length; position = bufferOrOptions.position || null; } - validateBuffer(buffer); - if (offset == null) { offset = 0; } else {