1// Copyright Joyent, Inc. and other Node contributors.
2//
3// Permission is hereby granted, free of charge, to any person obtaining a
4// copy of this software and associated documentation files (the
5// "Software"), to deal in the Software without restriction, including
6// without limitation the rights to use, copy, modify, merge, publish,
7// distribute, sublicense, and/or sell copies of the Software, and to permit
8// persons to whom the Software is furnished to do so, subject to the
9// following conditions:
10//
11// The above copyright notice and this permission notice shall be included
12// in all copies or substantial portions of the Software.
13//
14// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
15// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
17// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
18// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
19// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
20// USE OR OTHER DEALINGS IN THE SOFTWARE.
21
22'use strict';
23const common = require('../common');
24const assert = require('assert');
25
26const spawnSync = require('child_process').spawnSync;
27const { debuglog, getSystemErrorName } = require('util');
28const debug = debuglog('test');
29
30const TIMER = 200;
31let SLEEP = common.platformTimeout(5000);
32
33if (common.isWindows) {
34  // Some of the windows machines in the CI need more time to launch
35  // and receive output from child processes.
36  // https://github.com/nodejs/build/issues/3014
37  SLEEP = common.platformTimeout(15000);
38}
39
40switch (process.argv[2]) {
41  case 'child':
42    setTimeout(() => {
43      debug('child fired');
44      process.exit(1);
45    }, SLEEP);
46    break;
47  default: {
48    const start = Date.now();
49    const ret = spawnSync(process.execPath, [__filename, 'child'],
50                          { timeout: TIMER });
51    assert.strictEqual(ret.error.code, 'ETIMEDOUT');
52    assert.strictEqual(getSystemErrorName(ret.error.errno), 'ETIMEDOUT');
53    const end = Date.now() - start;
54    assert(end < SLEEP);
55    assert(ret.status > 128 || ret.signal);
56    break;
57  }
58}
59