mirror of
https://github.com/nodejs/node.git
synced 2025-05-03 09:52:21 +00:00

Support creating a Read/WriteStream from a FileHandle instead of a raw file descriptor Add an EventEmitter to FileHandle with a single 'close' event. Fixes: https://github.com/nodejs/node/issues/35240 PR-URL: https://github.com/nodejs/node/pull/35922 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Rich Trott <rtrott@gmail.com>
51 lines
1.3 KiB
JavaScript
51 lines
1.3 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const fs = require('fs');
|
|
const assert = require('assert');
|
|
const path = require('path');
|
|
const tmpdir = require('../common/tmpdir');
|
|
const file = path.join(tmpdir.path, 'read_stream_filehandle_worker.txt');
|
|
const input = 'hello world';
|
|
const { Worker, isMainThread, workerData } = require('worker_threads');
|
|
|
|
if (isMainThread || !workerData) {
|
|
tmpdir.refresh();
|
|
fs.writeFileSync(file, input);
|
|
|
|
fs.promises.open(file, 'r').then((handle) => {
|
|
handle.on('close', common.mustNotCall());
|
|
new Worker(__filename, {
|
|
workerData: { handle },
|
|
transferList: [handle]
|
|
});
|
|
});
|
|
fs.promises.open(file, 'r').then((handle) => {
|
|
fs.createReadStream(null, { fd: handle });
|
|
assert.throws(() => {
|
|
new Worker(__filename, {
|
|
workerData: { handle },
|
|
transferList: [handle]
|
|
});
|
|
}, {
|
|
code: 25,
|
|
});
|
|
});
|
|
} else {
|
|
let output = '';
|
|
|
|
const handle = workerData.handle;
|
|
handle.on('close', common.mustCall());
|
|
const stream = fs.createReadStream(null, { fd: handle });
|
|
|
|
stream.on('data', common.mustCallAtLeast((data) => {
|
|
output += data;
|
|
}));
|
|
|
|
stream.on('end', common.mustCall(() => {
|
|
handle.close();
|
|
assert.strictEqual(output, input);
|
|
}));
|
|
|
|
stream.on('close', common.mustCall());
|
|
}
|