forked from nodejs/node
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathtest-stdio-pipe-stderr.js
More file actions
36 lines (32 loc) · 1.16 KB
/
test-stdio-pipe-stderr.js
File metadata and controls
36 lines (32 loc) · 1.16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
'use strict';
const common = 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', common.mustCall(() => {
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);
}));