mirror of
https://github.com/denoland/deno.git
synced 2025-01-21 13:00:36 -05:00
fix(ext/node): accept file descriptor in fs.readFile(Sync) (#27252)
closes #27123
This commit is contained in:
parent
1ee13a3544
commit
07737b03bc
4 changed files with 120 additions and 11 deletions
|
@ -10,7 +10,7 @@ import {
|
||||||
TextOptionsArgument,
|
TextOptionsArgument,
|
||||||
} from "ext:deno_node/_fs/_fs_common.ts";
|
} from "ext:deno_node/_fs/_fs_common.ts";
|
||||||
import { Buffer } from "node:buffer";
|
import { Buffer } from "node:buffer";
|
||||||
import { readAll } from "ext:deno_io/12_io.js";
|
import { readAll, readAllSync } from "ext:deno_io/12_io.js";
|
||||||
import { FileHandle } from "ext:deno_node/internal/fs/handle.ts";
|
import { FileHandle } from "ext:deno_node/internal/fs/handle.ts";
|
||||||
import { pathFromURL } from "ext:deno_web/00_infra.js";
|
import { pathFromURL } from "ext:deno_web/00_infra.js";
|
||||||
import {
|
import {
|
||||||
|
@ -39,7 +39,7 @@ type TextCallback = (err: Error | null, data?: string) => void;
|
||||||
type BinaryCallback = (err: Error | null, data?: Buffer) => void;
|
type BinaryCallback = (err: Error | null, data?: Buffer) => void;
|
||||||
type GenericCallback = (err: Error | null, data?: string | Buffer) => void;
|
type GenericCallback = (err: Error | null, data?: string | Buffer) => void;
|
||||||
type Callback = TextCallback | BinaryCallback | GenericCallback;
|
type Callback = TextCallback | BinaryCallback | GenericCallback;
|
||||||
type Path = string | URL | FileHandle;
|
type Path = string | URL | FileHandle | number;
|
||||||
|
|
||||||
export function readFile(
|
export function readFile(
|
||||||
path: Path,
|
path: Path,
|
||||||
|
@ -76,6 +76,9 @@ export function readFile(
|
||||||
if (path instanceof FileHandle) {
|
if (path instanceof FileHandle) {
|
||||||
const fsFile = new FsFile(path.fd, Symbol.for("Deno.internal.FsFile"));
|
const fsFile = new FsFile(path.fd, Symbol.for("Deno.internal.FsFile"));
|
||||||
p = readAll(fsFile);
|
p = readAll(fsFile);
|
||||||
|
} else if (typeof path === "number") {
|
||||||
|
const fsFile = new FsFile(path, Symbol.for("Deno.internal.FsFile"));
|
||||||
|
p = readAll(fsFile);
|
||||||
} else {
|
} else {
|
||||||
p = Deno.readFile(path);
|
p = Deno.readFile(path);
|
||||||
}
|
}
|
||||||
|
@ -106,23 +109,28 @@ export function readFilePromise(
|
||||||
}
|
}
|
||||||
|
|
||||||
export function readFileSync(
|
export function readFileSync(
|
||||||
path: string | URL,
|
path: string | URL | number,
|
||||||
opt: TextOptionsArgument,
|
opt: TextOptionsArgument,
|
||||||
): string;
|
): string;
|
||||||
export function readFileSync(
|
export function readFileSync(
|
||||||
path: string | URL,
|
path: string | URL | number,
|
||||||
opt?: BinaryOptionsArgument,
|
opt?: BinaryOptionsArgument,
|
||||||
): Buffer;
|
): Buffer;
|
||||||
export function readFileSync(
|
export function readFileSync(
|
||||||
path: string | URL,
|
path: string | URL | number,
|
||||||
opt?: FileOptionsArgument,
|
opt?: FileOptionsArgument,
|
||||||
): string | Buffer {
|
): string | Buffer {
|
||||||
path = path instanceof URL ? pathFromURL(path) : path;
|
path = path instanceof URL ? pathFromURL(path) : path;
|
||||||
let data;
|
let data;
|
||||||
try {
|
if (typeof path === "number") {
|
||||||
data = Deno.readFileSync(path);
|
const fsFile = new FsFile(path, Symbol.for("Deno.internal.FsFile"));
|
||||||
} catch (err) {
|
data = readAllSync(fsFile);
|
||||||
throw denoErrorToNodeError(err, { path, syscall: "open" });
|
} else {
|
||||||
|
try {
|
||||||
|
data = Deno.readFileSync(path);
|
||||||
|
} catch (err) {
|
||||||
|
throw denoErrorToNodeError(err, { path, syscall: "open" });
|
||||||
|
}
|
||||||
}
|
}
|
||||||
const encoding = getEncoding(opt);
|
const encoding = getEncoding(opt);
|
||||||
if (encoding && encoding !== "binary") {
|
if (encoding && encoding !== "binary") {
|
||||||
|
|
|
@ -503,6 +503,7 @@
|
||||||
"test-fs-readdir-stack-overflow.js",
|
"test-fs-readdir-stack-overflow.js",
|
||||||
"test-fs-readdir.js",
|
"test-fs-readdir.js",
|
||||||
"test-fs-readfile-empty.js",
|
"test-fs-readfile-empty.js",
|
||||||
|
"test-fs-readfile-fd.js",
|
||||||
"test-fs-readfile-unlink.js",
|
"test-fs-readfile-unlink.js",
|
||||||
"test-fs-readfile-zero-byte-liar.js",
|
"test-fs-readfile-zero-byte-liar.js",
|
||||||
"test-fs-readfilesync-enoent.js",
|
"test-fs-readfilesync-enoent.js",
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<!-- deno-fmt-ignore-file -->
|
<!-- deno-fmt-ignore-file -->
|
||||||
# Remaining Node Tests
|
# Remaining Node Tests
|
||||||
|
|
||||||
1163 tests out of 3681 have been ported from Node 20.11.1 (31.59% ported, 68.92% remaining).
|
1164 tests out of 3681 have been ported from Node 20.11.1 (31.62% ported, 68.89% remaining).
|
||||||
|
|
||||||
NOTE: This file should not be manually edited. Please edit `tests/node_compat/config.json` and run `deno task setup` in `tests/node_compat/runner` dir instead.
|
NOTE: This file should not be manually edited. Please edit `tests/node_compat/config.json` and run `deno task setup` in `tests/node_compat/runner` dir instead.
|
||||||
|
|
||||||
|
@ -691,7 +691,6 @@ NOTE: This file should not be manually edited. Please edit `tests/node_compat/co
|
||||||
- [parallel/test-fs-readdir-types.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readdir-types.js)
|
- [parallel/test-fs-readdir-types.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readdir-types.js)
|
||||||
- [parallel/test-fs-readdir-ucs2.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readdir-ucs2.js)
|
- [parallel/test-fs-readdir-ucs2.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readdir-ucs2.js)
|
||||||
- [parallel/test-fs-readfile-error.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readfile-error.js)
|
- [parallel/test-fs-readfile-error.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readfile-error.js)
|
||||||
- [parallel/test-fs-readfile-fd.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readfile-fd.js)
|
|
||||||
- [parallel/test-fs-readfile-flags.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readfile-flags.js)
|
- [parallel/test-fs-readfile-flags.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readfile-flags.js)
|
||||||
- [parallel/test-fs-readfile-pipe-large.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readfile-pipe-large.js)
|
- [parallel/test-fs-readfile-pipe-large.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readfile-pipe-large.js)
|
||||||
- [parallel/test-fs-readfile-pipe.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readfile-pipe.js)
|
- [parallel/test-fs-readfile-pipe.js](https://github.com/nodejs/node/tree/v20.11.1/test/parallel/test-fs-readfile-pipe.js)
|
||||||
|
|
101
tests/node_compat/test/parallel/test-fs-readfile-fd.js
Normal file
101
tests/node_compat/test/parallel/test-fs-readfile-fd.js
Normal file
|
@ -0,0 +1,101 @@
|
||||||
|
// deno-fmt-ignore-file
|
||||||
|
// deno-lint-ignore-file
|
||||||
|
|
||||||
|
// Copyright Joyent and Node contributors. All rights reserved. MIT license.
|
||||||
|
// Taken from Node 20.11.1
|
||||||
|
// This file is automatically generated by `tests/node_compat/runner/setup.ts`. Do not modify this file manually.
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
const common = require('../common');
|
||||||
|
|
||||||
|
// Test fs.readFile using a file descriptor.
|
||||||
|
|
||||||
|
const fixtures = require('../common/fixtures');
|
||||||
|
const assert = require('assert');
|
||||||
|
const fs = require('fs');
|
||||||
|
const fn = fixtures.path('empty.txt');
|
||||||
|
const tmpdir = require('../common/tmpdir');
|
||||||
|
tmpdir.refresh();
|
||||||
|
|
||||||
|
tempFd(function(fd, close) {
|
||||||
|
fs.readFile(fd, function(err, data) {
|
||||||
|
assert.ok(data);
|
||||||
|
close();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
tempFd(function(fd, close) {
|
||||||
|
fs.readFile(fd, 'utf8', function(err, data) {
|
||||||
|
assert.strictEqual(data, '');
|
||||||
|
close();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
tempFdSync(function(fd) {
|
||||||
|
assert.ok(fs.readFileSync(fd));
|
||||||
|
});
|
||||||
|
|
||||||
|
tempFdSync(function(fd) {
|
||||||
|
assert.strictEqual(fs.readFileSync(fd, 'utf8'), '');
|
||||||
|
});
|
||||||
|
|
||||||
|
function tempFd(callback) {
|
||||||
|
fs.open(fn, 'r', function(err, fd) {
|
||||||
|
assert.ifError(err);
|
||||||
|
callback(fd, function() {
|
||||||
|
fs.close(fd, function(err) {
|
||||||
|
assert.ifError(err);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function tempFdSync(callback) {
|
||||||
|
const fd = fs.openSync(fn, 'r');
|
||||||
|
callback(fd);
|
||||||
|
fs.closeSync(fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
// This test makes sure that `readFile()` always reads from the current
|
||||||
|
// position of the file, instead of reading from the beginning of the file,
|
||||||
|
// when used with file descriptors.
|
||||||
|
|
||||||
|
const filename = tmpdir.resolve('test.txt');
|
||||||
|
fs.writeFileSync(filename, 'Hello World');
|
||||||
|
|
||||||
|
{
|
||||||
|
// Tests the fs.readFileSync().
|
||||||
|
const fd = fs.openSync(filename, 'r');
|
||||||
|
|
||||||
|
// Read only five bytes, so that the position moves to five.
|
||||||
|
const buf = Buffer.alloc(5);
|
||||||
|
assert.strictEqual(fs.readSync(fd, buf, 0, 5), 5);
|
||||||
|
assert.strictEqual(buf.toString(), 'Hello');
|
||||||
|
|
||||||
|
// readFileSync() should read from position five, instead of zero.
|
||||||
|
assert.strictEqual(fs.readFileSync(fd).toString(), ' World');
|
||||||
|
|
||||||
|
fs.closeSync(fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
// Tests the fs.readFile().
|
||||||
|
fs.open(filename, 'r', common.mustSucceed((fd) => {
|
||||||
|
const buf = Buffer.alloc(5);
|
||||||
|
|
||||||
|
// Read only five bytes, so that the position moves to five.
|
||||||
|
fs.read(fd, buf, 0, 5, null, common.mustSucceed((bytes) => {
|
||||||
|
assert.strictEqual(bytes, 5);
|
||||||
|
assert.strictEqual(buf.toString(), 'Hello');
|
||||||
|
|
||||||
|
fs.readFile(fd, common.mustSucceed((data) => {
|
||||||
|
// readFile() should read from position five, instead of zero.
|
||||||
|
assert.strictEqual(data.toString(), ' World');
|
||||||
|
|
||||||
|
fs.closeSync(fd);
|
||||||
|
}));
|
||||||
|
}));
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue