mirror of
https://github.com/nodejs/node.git
synced 2024-11-21 21:19:50 +01:00
966e3d3493
PR-URL: https://github.com/nodejs/node/pull/49128 Reviewed-By: Michaël Zasso <targos@protonmail.com> Reviewed-By: Benjamin Gruenbaum <benjamingr@gmail.com>
37 lines
1.1 KiB
JavaScript
37 lines
1.1 KiB
JavaScript
'use strict';
|
|
require('../common');
|
|
const tmpdir = require('../common/tmpdir');
|
|
const assert = require('assert');
|
|
const fs = require('fs');
|
|
const { spawnSync } = require('child_process');
|
|
|
|
// Test that invoking node with require, and piping stderr to file,
|
|
// does not result in exception,
|
|
// see: https://github.com/nodejs/node/issues/11257
|
|
|
|
tmpdir.refresh();
|
|
const fakeModulePath = tmpdir.resolve('batman.js');
|
|
const stderrOutputPath = tmpdir.resolve('stderr-output.txt');
|
|
// We need to redirect stderr to a file to produce #11257
|
|
const stream = fs.createWriteStream(stderrOutputPath);
|
|
|
|
// The error described in #11257 only happens when we require a
|
|
// non-built-in module.
|
|
fs.writeFileSync(fakeModulePath, '', 'utf8');
|
|
|
|
stream.on('open', () => {
|
|
spawnSync(process.execPath, {
|
|
input: `require(${JSON.stringify(fakeModulePath)})`,
|
|
stdio: ['pipe', 'pipe', stream]
|
|
});
|
|
const stderr = fs.readFileSync(stderrOutputPath, 'utf8').trim();
|
|
assert.strictEqual(
|
|
stderr,
|
|
'',
|
|
`piping stderr to file should not result in exception: ${stderr}`
|
|
);
|
|
stream.end();
|
|
fs.unlinkSync(stderrOutputPath);
|
|
fs.unlinkSync(fakeModulePath);
|
|
});
|