Skip to content

Commit

Permalink
fs: support pseudofiles in promises.readFile
Browse files Browse the repository at this point in the history
  • Loading branch information
TimothyGu committed Jul 4, 2018
1 parent c01601e commit 16233aa
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 20 deletions.
9 changes: 2 additions & 7 deletions lib/internal/fs/promises.js
Original file line number Diff line number Diff line change
Expand Up @@ -135,21 +135,16 @@ async function readFileHandle(filehandle, options) {
size = 0;
}

if (size === 0)
return options.encoding ? '' : Buffer.alloc(0);

if (size > kMaxLength)
throw new ERR_FS_FILE_TOO_LARGE(size);

const chunks = [];
const chunkSize = Math.min(size, 16384);
let totalRead = 0;
const chunkSize = size === 0 ? 16384 : Math.min(size, 16384);
let endOfFile = false;
do {
const buf = Buffer.alloc(chunkSize);
const { bytesRead, buffer } =
await read(filehandle, buf, 0, chunkSize, totalRead);
totalRead += bytesRead;
await read(filehandle, buf, 0, chunkSize, -1);
endOfFile = bytesRead !== chunkSize;
if (bytesRead > 0)
chunks.push(buffer.slice(0, bytesRead));
Expand Down
17 changes: 17 additions & 0 deletions test/parallel/test-fs-promises-file-handle-readFile.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,5 +28,22 @@ async function validateReadFile() {
assert.deepStrictEqual(buffer, readFileData);
}

async function validateReadFileProc() {
// Test to make sure reading a file under the /proc directory works. Adapted
// from test-fs-read-file-sync-hostname.js.
// Refs:
// - https://groups.google.com/forum/#!topic/nodejs-dev/rxZ_RoH1Gn0
// - https://github.com/nodejs/node/issues/21331

// Test is Linux-specific.
if (!common.isLinux)
return;

const fileHandle = await open('/proc/sys/kernel/hostname', 'r');
const hostname = await fileHandle.readFile();
assert.ok(hostname.length > 0);
}

validateReadFile()
.then(() => validateReadFileProc())
.then(common.mustCall());
44 changes: 31 additions & 13 deletions test/parallel/test-fs-promises-readfile.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,17 +12,35 @@ const fn = path.join(tmpdir.path, 'large-file');

common.crashOnUnhandledRejection();

// Creating large buffer with random content
const buffer = Buffer.from(
Array.apply(null, { length: 16834 * 2 })
.map(Math.random)
.map((number) => (number * (1 << 8)))
);

// Writing buffer to a file then try to read it
writeFile(fn, buffer)
.then(() => readFile(fn))
.then((readBuffer) => {
assert.strictEqual(readBuffer.equals(buffer), true);
})
async function validateReadFile() {
// Creating large buffer with random content
const buffer = Buffer.from(
Array.apply(null, { length: 16834 * 2 })
.map(Math.random)
.map((number) => (number * (1 << 8)))
);

// Writing buffer to a file then try to read it
await writeFile(fn, buffer);
const readBuffer = await readFile(fn);
assert.strictEqual(readBuffer.equals(buffer), true);
}

async function validateReadFileProc() {
// Test to make sure reading a file under the /proc directory works. Adapted
// from test-fs-read-file-sync-hostname.js.
// Refs:
// - https://groups.google.com/forum/#!topic/nodejs-dev/rxZ_RoH1Gn0
// - https://github.com/nodejs/node/issues/21331

// Test is Linux-specific.
if (!common.isLinux)
return;

const hostname = await readFile('/proc/sys/kernel/hostname');
assert.ok(hostname.length > 0);
}

validateReadFile()
.then(() => validateReadFileProc())
.then(common.mustCall());

0 comments on commit 16233aa

Please sign in to comment.