mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 10:59:27 +00:00
c63d511c13
This patch splits the handling of `isMainThread` and `ownsProcessState` from conditionals in `lib/internal/bootstrap/node.js` into different scripts under `lib/internal/bootstrap/switches/`, and call them accordingly from C++ after `node.js` is run. This: - Creates a common denominator of the main thread and the worker thread bootstrap that can be snapshotted and shared by both. - Makes it possible to override the configurations on-the-fly. PR-URL: https://github.com/nodejs/node/pull/30862 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Chengzhong Wu <legendecas@gmail.com>
30 lines
1.1 KiB
JavaScript
30 lines
1.1 KiB
JavaScript
'use strict';
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
const child_process = require('child_process');
|
|
|
|
if (common.isWindows)
|
|
common.skip('fs.closeSync(n) does not close stdio on Windows');
|
|
|
|
function runTest(fd, streamName, testOutputStream, expectedName) {
|
|
const result = child_process.spawnSync(process.execPath, [
|
|
'--expose-internals',
|
|
'--no-warnings',
|
|
'-e',
|
|
`const { internalBinding } = require('internal/test/binding');
|
|
internalBinding('process_methods').resetStdioForTesting();
|
|
fs.closeSync(${fd});
|
|
const ctorName = process.${streamName}.constructor.name;
|
|
process.${testOutputStream}.write(ctorName);
|
|
`]);
|
|
assert.strictEqual(result[testOutputStream].toString(), expectedName,
|
|
`stdout:\n${result.stdout}\nstderr:\n${result.stderr}\n` +
|
|
`while running test with fd = ${fd}`);
|
|
if (testOutputStream !== 'stderr')
|
|
assert.strictEqual(result.stderr.toString(), '');
|
|
}
|
|
|
|
runTest(0, 'stdin', 'stdout', 'Readable');
|
|
runTest(1, 'stdout', 'stderr', 'Writable');
|
|
runTest(2, 'stderr', 'stdout', 'Writable');
|