mirror of
https://github.com/nodejs/node.git
synced 2025-05-11 08:06:27 +00:00

Notable changes: - `uv_ip_name()` has been added. - On Windows, `uv_fs_read()` and `uv_fs_write()` now return `UV_EBADF` instead of `UV_EPERM` when the file descriptor was opened with incorrect flags. This matches the behavior on other platforms. - Streams can be reset and attempted to read from after EOF is read. - The main thread now has a valid ID instead of `NULL`. - `uv_cpu_info()` now supports `aarch64`. - Several minor issues related to mingw32 have been fixed. PR-URL: https://github.com/nodejs/node/pull/41398 Reviewed-By: Richard Lau <rlau@redhat.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Tobias Nießen <tniessen@tnie.de> Reviewed-By: Mohammed Keyvanzadeh <mohammadkeyvanzade94@gmail.com> Reviewed-By: Rich Trott <rtrott@gmail.com> Reviewed-By: Beth Griggs <bgriggs@redhat.com> Reviewed-By: Anna Henningsen <anna@addaleax.net>
94 lines
2.5 KiB
JavaScript
94 lines
2.5 KiB
JavaScript
'use strict';
|
|
|
|
// This test makes sure that `writeFile()` always writes from the current
|
|
// position of the file, instead of truncating the file, when used with file
|
|
// descriptors.
|
|
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const fs = require('fs');
|
|
const join = require('path').join;
|
|
|
|
const tmpdir = require('../common/tmpdir');
|
|
tmpdir.refresh();
|
|
|
|
{
|
|
/* writeFileSync() test. */
|
|
const filename = join(tmpdir.path, 'test.txt');
|
|
|
|
/* Open the file descriptor. */
|
|
const fd = fs.openSync(filename, 'w');
|
|
try {
|
|
/* Write only five characters, so that the position moves to five. */
|
|
assert.strictEqual(fs.writeSync(fd, 'Hello'), 5);
|
|
assert.strictEqual(fs.readFileSync(filename).toString(), 'Hello');
|
|
|
|
/* Write some more with writeFileSync(). */
|
|
fs.writeFileSync(fd, 'World');
|
|
|
|
/* New content should be written at position five, instead of zero. */
|
|
assert.strictEqual(fs.readFileSync(filename).toString(), 'HelloWorld');
|
|
} finally {
|
|
fs.closeSync(fd);
|
|
}
|
|
}
|
|
|
|
const fdsToCloseOnExit = [];
|
|
process.on('beforeExit', common.mustCall(() => {
|
|
for (const fd of fdsToCloseOnExit) {
|
|
try {
|
|
fs.closeSync(fd);
|
|
} catch {
|
|
// Failed to close, ignore
|
|
}
|
|
}
|
|
}));
|
|
|
|
{
|
|
/* writeFile() test. */
|
|
const file = join(tmpdir.path, 'test1.txt');
|
|
|
|
/* Open the file descriptor. */
|
|
fs.open(file, 'w', common.mustSucceed((fd) => {
|
|
fdsToCloseOnExit.push(fd);
|
|
/* Write only five characters, so that the position moves to five. */
|
|
fs.write(fd, 'Hello', common.mustSucceed((bytes) => {
|
|
assert.strictEqual(bytes, 5);
|
|
assert.strictEqual(fs.readFileSync(file).toString(), 'Hello');
|
|
|
|
/* Write some more with writeFile(). */
|
|
fs.writeFile(fd, 'World', common.mustSucceed(() => {
|
|
/* New content should be written at position five, instead of zero. */
|
|
assert.strictEqual(fs.readFileSync(file).toString(), 'HelloWorld');
|
|
}));
|
|
}));
|
|
}));
|
|
}
|
|
|
|
|
|
// Test read-only file descriptor
|
|
{
|
|
const file = join(tmpdir.path, 'test.txt');
|
|
|
|
fs.open(file, 'r', common.mustSucceed((fd) => {
|
|
fdsToCloseOnExit.push(fd);
|
|
fs.writeFile(fd, 'World', common.expectsError(/EBADF/));
|
|
}));
|
|
}
|
|
|
|
// Test with an AbortSignal
|
|
{
|
|
const controller = new AbortController();
|
|
const signal = controller.signal;
|
|
const file = join(tmpdir.path, 'test.txt');
|
|
|
|
fs.open(file, 'w', common.mustSucceed((fd) => {
|
|
fdsToCloseOnExit.push(fd);
|
|
fs.writeFile(fd, 'World', { signal }, common.expectsError({
|
|
name: 'AbortError'
|
|
}));
|
|
}));
|
|
|
|
controller.abort();
|
|
}
|