teen_process 2.0.0 → 2.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/lib/exec.js CHANGED
@@ -24,7 +24,7 @@ const MAX_BUFFER_SIZE = 100 * 1024 * 1024;
24
24
 
25
25
  async function exec(cmd, args = [], opts = {}) {
26
26
  const rep = (0, _shellQuote.quote)([cmd, ...args]);
27
- opts = Object.assign({
27
+ opts = _lodash.default.defaults(opts, {
28
28
  timeout: null,
29
29
  encoding: 'utf8',
30
30
  killSignal: 'SIGTERM',
@@ -37,7 +37,8 @@ async function exec(cmd, args = [], opts = {}) {
37
37
  logger: undefined,
38
38
  maxStdoutBufferSize: MAX_BUFFER_SIZE,
39
39
  maxStderrBufferSize: MAX_BUFFER_SIZE
40
- }, opts);
40
+ });
41
+ const isBuffer = Boolean(opts.isBuffer);
41
42
  return await new _bluebird.default((resolve, reject) => {
42
43
  let proc = (0, _child_process.spawn)(cmd, args, {
43
44
  cwd: opts.cwd,
@@ -129,7 +130,7 @@ async function exec(cmd, args = [], opts = {}) {
129
130
  let {
130
131
  stdout,
131
132
  stderr
132
- } = getStdio(opts.isBuffer);
133
+ } = getStdio(isBuffer);
133
134
 
134
135
  if (code === 0) {
135
136
  resolve({
@@ -153,7 +154,7 @@ async function exec(cmd, args = [], opts = {}) {
153
154
  let {
154
155
  stdout,
155
156
  stderr
156
- } = getStdio(opts.isBuffer);
157
+ } = getStdio(isBuffer);
157
158
  let err = new Error(`Command '${rep}' timed out after ${opts.timeout}ms`);
158
159
  err = Object.assign(err, {
159
160
  stdout,
@@ -168,7 +169,5 @@ async function exec(cmd, args = [], opts = {}) {
168
169
  }
169
170
 
170
171
  var _default = exec;
171
- exports.default = _default;require('source-map-support').install();
172
-
173
-
174
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"lib/exec.js","names":["MAX_BUFFER_SIZE","exec","cmd","args","opts","rep","quote","Object","assign","timeout","encoding","killSignal","cwd","undefined","env","process","ignoreOutput","stdio","isBuffer","shell","logger","maxStdoutBufferSize","maxStderrBufferSize","B","resolve","reject","proc","spawn","stdoutArr","stderrArr","timer","on","err","errno","formatEnoent","stdin","Error","syscall","stack","handleStream","streamType","streamProps","_","capitalize","chunks","maxSize","size","chunk","push","length","shift","isFunction","debug","toString","getStdio","stdout","stderr","Buffer","concat","code","clearTimeout","setTimeout","kill"],"sourceRoot":"../..","sources":["lib/exec.js"],"sourcesContent":["// @ts-check\n\n/* eslint-disable promise/prefer-await-to-callbacks */\n\nimport { spawn } from 'child_process';\nimport { quote } from 'shell-quote';\nimport B from 'bluebird';\nimport _ from 'lodash';\nimport { formatEnoent } from './helpers';\n\nconst MAX_BUFFER_SIZE = 100 * 1024 * 1024;\n\n/**\n * Spawns a process\n * @template {TeenProcessExecOptions} T\n * @param {string} cmd - Program to execute\n * @param {string[]} [args] - Arguments to pass to the program\n * @param {T} [opts] - Options\n * @returns {Promise<BufferProp<T> extends true ? TeenProcessExecBufferResult : TeenProcessExecStringResult>}\n */\nasync function exec (cmd, args = [], opts = /** @type {T} */({})) {\n  // get a quoted representation of the command for error strings\n  const rep = quote([cmd, ...args]);\n\n  // extend default options; we're basically re-implementing exec's options\n  // for use here with spawn under the hood\n  opts = Object.assign({\n    timeout: null,\n    encoding: 'utf8',\n    killSignal: 'SIGTERM',\n    cwd: undefined,\n    env: process.env,\n    ignoreOutput: false,\n    stdio: 'inherit',\n    isBuffer: false,\n    shell: undefined,\n    logger: undefined,\n    maxStdoutBufferSize: MAX_BUFFER_SIZE,\n    maxStderrBufferSize: MAX_BUFFER_SIZE,\n  }, opts);\n\n  // this is an async function, so return a promise\n  return await new B((resolve, reject) => {\n    // spawn the child process with options; we don't currently expose any of\n    // the other 'spawn' options through the API\n    let proc = spawn(cmd, args, {cwd: opts.cwd, env: opts.env, shell: opts.shell});\n    let stdoutArr = [], stderrArr = [], timer = null;\n\n    // if the process errors out, reject the promise\n    proc.on('error', /** @param {NodeJS.ErrnoException} err */(err) => {\n      // @ts-ignore\n      if (err.errno === 'ENOENT') {\n        err = formatEnoent(err, cmd, opts.cwd);\n      }\n      reject(err);\n    });\n    if (proc.stdin) {\n      proc.stdin.on('error', /** @param {NodeJS.ErrnoException} err */(err) => {\n        reject(new Error(`Standard input '${err.syscall}' error: ${err.stack}`));\n      });\n    }\n    const handleStream = (streamType, streamProps) => {\n      if (!proc[streamType]) {\n        return;\n      }\n\n      proc[streamType].on('error', (err) => {\n        reject(new Error(`${_.capitalize(streamType)} '${err.syscall}' error: ${err.stack}`));\n      });\n\n      if (opts.ignoreOutput) {\n        // https://github.com/nodejs/node/issues/4236\n        proc[streamType].on('data', () => {});\n        return;\n      }\n\n      // keep track of the stream if we don't want to ignore it\n      const {chunks, maxSize} = streamProps;\n      let size = 0;\n      proc[streamType].on('data', (chunk) => {\n        chunks.push(chunk);\n        size += chunk.length;\n        while (chunks.length > 1 && size >= maxSize) {\n          size -= chunks[0].length;\n          chunks.shift();\n        }\n        if (opts.logger && _.isFunction(opts.logger.debug)) {\n          opts.logger.debug(chunk.toString());\n        }\n      });\n    };\n    handleStream('stdout', {\n      maxSize: opts.maxStdoutBufferSize,\n      chunks: stdoutArr,\n    });\n    handleStream('stderr', {\n      maxSize: opts.maxStderrBufferSize,\n      chunks: stderrArr,\n    });\n\n    /**\n     * @template {boolean} U\n     * @param {U} isBuffer\n     * @returns {U extends true ? {stdout: Buffer, stderr: Buffer} : {stdout: string, stderr: string}}\n     */\n    function getStdio (isBuffer) {\n      let stdout, stderr;\n      if (isBuffer) {\n        stdout = Buffer.concat(stdoutArr);\n        stderr = Buffer.concat(stderrArr);\n      } else {\n        stdout = Buffer.concat(stdoutArr).toString(opts.encoding);\n        stderr = Buffer.concat(stderrArr).toString(opts.encoding);\n      }\n      return /** @type {U extends true ? {stdout: Buffer, stderr: Buffer} : {stdout: string, stderr: string}} */({stdout, stderr});\n    }\n\n    // if the process ends, either resolve or reject the promise based on the\n    // exit code of the process. either way, attach stdout, stderr, and code.\n    // Also clean up the timer if it exists\n    proc.on('close', (code) => {\n      if (timer) {\n        clearTimeout(timer);\n      }\n      let {stdout, stderr} = getStdio(opts.isBuffer);\n      if (code === 0) {\n        resolve(/** @type {BufferProp<T> extends true ? TeenProcessExecBufferResult : TeenProcessExecStringResult} */({stdout, stderr, code}));\n      } else {\n        let err = new Error(`Command '${rep}' exited with code ${code}`);\n        err = Object.assign(err, {stdout, stderr, code});\n        reject(err);\n      }\n    });\n\n    // if we set a timeout on the child process, cut into the execution and\n    // reject if the timeout is reached. Attach the stdout/stderr we currently\n    // have in case it's helpful in debugging\n    if (opts.timeout) {\n      timer = setTimeout(() => {\n        let {stdout, stderr} = getStdio(opts.isBuffer);\n        let err = new Error(`Command '${rep}' timed out after ${opts.timeout}ms`);\n        err = Object.assign(err, {stdout, stderr, code: null});\n        reject(err);\n        // reject and THEN kill to avoid race conditions with the handlers\n        // above\n        proc.kill(opts.killSignal);\n      }, opts.timeout);\n    }\n  });\n}\n\nexport { exec };\nexport default exec;\n\n/**\n * Options on top of `SpawnOptions`, unique to `teen_process.`\n * @typedef {Object} TeenProcessProps\n * @property {boolean} [ignoreOutput] - Ignore & discard all output\n * @property {boolean} [isBuffer] - Return output as a Buffer\n * @property {TeenProcessLogger} [logger] - Logger to use for debugging\n * @property {number} [maxStdoutBufferSize] - Maximum size of `stdout` buffer\n * @property {number} [maxStderrBufferSize] - Maximum size of `stderr` buffer\n * @property {BufferEncoding} [encoding='utf8'] - Encoding to use for output\n */\n\n/**\n * A logger object understood by {@link exec teen_process.exec}.\n * @typedef {Object} TeenProcessLogger\n * @property {(...args: any[]) => void} debug\n */\n\n/**\n * Options for {@link exec teen_process.exec}.\n * @typedef {import('child_process').SpawnOptions & TeenProcessProps} TeenProcessExecOptions\n */\n\n/**\n * The value {@link exec teen_process.exec} resolves to when `isBuffer` is `false`\n * @typedef {Object} TeenProcessExecStringResult\n * @property {string} stdout - Stdout\n * @property {string} stderr - Stderr\n * @property {number?} code - Exit code\n */\n\n/**\n * The value {@link exec teen_process.exec} resolves to when `isBuffer` is `true`\n * @typedef {Object} TeenProcessExecBufferResult\n * @property {Buffer} stdout - Stdout\n * @property {Buffer} stderr - Stderr\n * @property {number?} code - Exit code\n */\n\n/**\n * Extra props {@link exec teen_process.exec} adds to its error objects\n * @typedef {Object} TeenProcessExecErrorProps\n * @property {string} stdout - STDOUT\n * @property {string} stderr - STDERR\n * @property {number?} code - Exit code\n */\n\n/**\n * Error thrown by {@link exec teen_process.exec}\n * @typedef {Error & TeenProcessExecErrorProps} TeenProcessExecError\n */\n\n/**\n * @template {{isBuffer?: boolean}} MaybeBuffer\n * @typedef {MaybeBuffer['isBuffer']} BufferProp\n * @private\n */\n"],"mappings":"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"}
172
+ exports.default = _default;
173
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["MAX_BUFFER_SIZE","exec","cmd","args","opts","rep","quote","_","defaults","timeout","encoding","killSignal","cwd","undefined","env","process","ignoreOutput","stdio","isBuffer","shell","logger","maxStdoutBufferSize","maxStderrBufferSize","Boolean","B","resolve","reject","proc","spawn","stdoutArr","stderrArr","timer","on","err","errno","formatEnoent","stdin","Error","syscall","stack","handleStream","streamType","streamProps","capitalize","chunks","maxSize","size","chunk","push","length","shift","isFunction","debug","toString","getStdio","stdout","stderr","Buffer","concat","code","clearTimeout","Object","assign","setTimeout","kill"],"sources":["../../lib/exec.js"],"sourcesContent":["/* eslint-disable promise/prefer-await-to-callbacks */\n\nimport { spawn } from 'child_process';\nimport { quote } from 'shell-quote';\nimport B from 'bluebird';\nimport _ from 'lodash';\nimport { formatEnoent } from './helpers';\n\nconst MAX_BUFFER_SIZE = 100 * 1024 * 1024;\n\n/**\n * Spawns a process\n * @template {TeenProcessExecOptions} T\n * @param {string} cmd - Program to execute\n * @param {string[]} [args] - Arguments to pass to the program\n * @param {T} [opts] - Options\n * @returns {Promise<BufferProp<T> extends true ? TeenProcessExecBufferResult : TeenProcessExecStringResult>}\n */\nasync function exec (cmd, args = [], opts = /** @type {T} */({})) {\n  // get a quoted representation of the command for error strings\n  const rep = quote([cmd, ...args]);\n\n  // extend default options; we're basically re-implementing exec's options\n  // for use here with spawn under the hood\n  opts = /** @type {T} */(_.defaults(opts, {\n    timeout: null,\n    encoding: 'utf8',\n    killSignal: 'SIGTERM',\n    cwd: undefined,\n    env: process.env,\n    ignoreOutput: false,\n    stdio: 'inherit',\n    isBuffer: false,\n    shell: undefined,\n    logger: undefined,\n    maxStdoutBufferSize: MAX_BUFFER_SIZE,\n    maxStderrBufferSize: MAX_BUFFER_SIZE,\n  }));\n\n  const isBuffer = Boolean(opts.isBuffer);\n\n  // this is an async function, so return a promise\n  return await new B((resolve, reject) => {\n    // spawn the child process with options; we don't currently expose any of\n    // the other 'spawn' options through the API\n    let proc = spawn(cmd, args, {cwd: opts.cwd, env: opts.env, shell: opts.shell});\n    let stdoutArr = [], stderrArr = [], timer = null;\n\n    // if the process errors out, reject the promise\n    proc.on('error', /** @param {NodeJS.ErrnoException} err */(err) => {\n      // @ts-ignore\n      if (err.errno === 'ENOENT') {\n        err = formatEnoent(err, cmd, opts.cwd);\n      }\n      reject(err);\n    });\n    if (proc.stdin) {\n      proc.stdin.on('error', /** @param {NodeJS.ErrnoException} err */(err) => {\n        reject(new Error(`Standard input '${err.syscall}' error: ${err.stack}`));\n      });\n    }\n    const handleStream = (streamType, streamProps) => {\n      if (!proc[streamType]) {\n        return;\n      }\n\n      proc[streamType].on('error', (err) => {\n        reject(new Error(`${_.capitalize(streamType)} '${err.syscall}' error: ${err.stack}`));\n      });\n\n      if (opts.ignoreOutput) {\n        // https://github.com/nodejs/node/issues/4236\n        proc[streamType].on('data', () => {});\n        return;\n      }\n\n      // keep track of the stream if we don't want to ignore it\n      const {chunks, maxSize} = streamProps;\n      let size = 0;\n      proc[streamType].on('data', (chunk) => {\n        chunks.push(chunk);\n        size += chunk.length;\n        while (chunks.length > 1 && size >= maxSize) {\n          size -= chunks[0].length;\n          chunks.shift();\n        }\n        if (opts.logger && _.isFunction(opts.logger.debug)) {\n          opts.logger.debug(chunk.toString());\n        }\n      });\n    };\n    handleStream('stdout', {\n      maxSize: opts.maxStdoutBufferSize,\n      chunks: stdoutArr,\n    });\n    handleStream('stderr', {\n      maxSize: opts.maxStderrBufferSize,\n      chunks: stderrArr,\n    });\n\n    /**\n     * @template {boolean} U\n     * @param {U} isBuffer\n     * @returns {U extends true ? {stdout: Buffer, stderr: Buffer} : {stdout: string, stderr: string}}\n     */\n    function getStdio (isBuffer) {\n      let stdout, stderr;\n      if (isBuffer) {\n        stdout = Buffer.concat(stdoutArr);\n        stderr = Buffer.concat(stderrArr);\n      } else {\n        stdout = Buffer.concat(stdoutArr).toString(opts.encoding);\n        stderr = Buffer.concat(stderrArr).toString(opts.encoding);\n      }\n      return /** @type {U extends true ? {stdout: Buffer, stderr: Buffer} : {stdout: string, stderr: string}} */({stdout, stderr});\n    }\n\n    // if the process ends, either resolve or reject the promise based on the\n    // exit code of the process. either way, attach stdout, stderr, and code.\n    // Also clean up the timer if it exists\n    proc.on('close', (code) => {\n      if (timer) {\n        clearTimeout(timer);\n      }\n      let {stdout, stderr} = getStdio(isBuffer);\n      if (code === 0) {\n        resolve(/** @type {BufferProp<T> extends true ? TeenProcessExecBufferResult : TeenProcessExecStringResult} */({stdout, stderr, code}));\n      } else {\n        let err = new Error(`Command '${rep}' exited with code ${code}`);\n        err = Object.assign(err, {stdout, stderr, code});\n        reject(err);\n      }\n    });\n\n    // if we set a timeout on the child process, cut into the execution and\n    // reject if the timeout is reached. Attach the stdout/stderr we currently\n    // have in case it's helpful in debugging\n    if (opts.timeout) {\n      timer = setTimeout(() => {\n        let {stdout, stderr} = getStdio(isBuffer);\n        let err = new Error(`Command '${rep}' timed out after ${opts.timeout}ms`);\n        err = Object.assign(err, {stdout, stderr, code: null});\n        reject(err);\n        // reject and THEN kill to avoid race conditions with the handlers\n        // above\n        proc.kill(opts.killSignal);\n      }, opts.timeout);\n    }\n  });\n}\n\nexport { exec };\nexport default exec;\n\n/**\n * Options on top of `SpawnOptions`, unique to `teen_process.`\n * @typedef {Object} TeenProcessProps\n * @property {boolean} [ignoreOutput] - Ignore & discard all output\n * @property {boolean} [isBuffer] - Return output as a Buffer\n * @property {TeenProcessLogger} [logger] - Logger to use for debugging\n * @property {number} [maxStdoutBufferSize] - Maximum size of `stdout` buffer\n * @property {number} [maxStderrBufferSize] - Maximum size of `stderr` buffer\n * @property {BufferEncoding} [encoding='utf8'] - Encoding to use for output\n */\n\n/**\n * A logger object understood by {@link exec teen_process.exec}.\n * @typedef {Object} TeenProcessLogger\n * @property {(...args: any[]) => void} debug\n */\n\n/**\n * Options for {@link exec teen_process.exec}.\n * @typedef {import('child_process').SpawnOptions & TeenProcessProps} TeenProcessExecOptions\n */\n\n/**\n * The value {@link exec teen_process.exec} resolves to when `isBuffer` is `false`\n * @typedef {Object} TeenProcessExecStringResult\n * @property {string} stdout - Stdout\n * @property {string} stderr - Stderr\n * @property {number?} code - Exit code\n */\n\n/**\n * The value {@link exec teen_process.exec} resolves to when `isBuffer` is `true`\n * @typedef {Object} TeenProcessExecBufferResult\n * @property {Buffer} stdout - Stdout\n * @property {Buffer} stderr - Stderr\n * @property {number?} code - Exit code\n */\n\n/**\n * Extra props {@link exec teen_process.exec} adds to its error objects\n * @typedef {Object} TeenProcessExecErrorProps\n * @property {string} stdout - STDOUT\n * @property {string} stderr - STDERR\n * @property {number?} code - Exit code\n */\n\n/**\n * Error thrown by {@link exec teen_process.exec}\n * @typedef {Error & TeenProcessExecErrorProps} TeenProcessExecError\n */\n\n/**\n * @template {{isBuffer?: boolean}} MaybeBuffer\n * @typedef {MaybeBuffer['isBuffer']} BufferProp\n * @private\n */\n"],"mappings":"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"}
@@ -19,7 +19,7 @@ function formatEnoent(error, cmd, cwd = null) {
19
19
 
20
20
  if (cwd) {
21
21
  try {
22
- _fs.default.accessSync(cwd, _fs.default.R_OK);
22
+ _fs.default.accessSync(cwd, _fs.default.constants.R_OK);
23
23
  } catch (ign) {
24
24
  error.message = `The current working directory '${cwd}' for '${cmd}' command ` + `either does not exist or is not accessible`;
25
25
  }
@@ -29,7 +29,5 @@ function formatEnoent(error, cmd, cwd = null) {
29
29
  }
30
30
 
31
31
  return error;
32
- }require('source-map-support').install();
33
-
34
-
35
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGliL2hlbHBlcnMuanMiLCJuYW1lcyI6WyJmb3JtYXRFbm9lbnQiLCJlcnJvciIsImNtZCIsImN3ZCIsIndoaWNoIiwic3luYyIsImZzIiwiYWNjZXNzU3luYyIsIlJfT0siLCJpZ24iLCJtZXNzYWdlIl0sInNvdXJjZVJvb3QiOiIuLi8uLiIsInNvdXJjZXMiOlsibGliL2hlbHBlcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHdoaWNoIGZyb20gJ3doaWNoJztcbmltcG9ydCBmcyBmcm9tICdmcyc7XG5cbi8qKlxuICogRGVjb3JhdGVzIEVOT0VOVCBlcnJvciByZWNlaXZlZCBmcm9tIGEgc3Bhd24gc3lzdGVtIGNhbGxcbiAqIHdpdGggYSBtb3JlIGRlc2NyaXB0aXZlIG1lc3NhZ2UsIHNvIGl0IGNvdWxkIGJlIHByb3Blcmx5IGhhbmRsZWQgYnkgYSB1c2VyLlxuICpcbiAqIEBwYXJhbSB7Tm9kZUpTLkVycm5vRXhjZXB0aW9ufSBlcnJvciBPcmlnaW5hbCBlcnJvciBpbnN0YW5jZS4gISEhIFRoZSBpbnN0YW5jZSBpcyBtdXRhdGVkIGFmdGVyXG4gKiB0aGlzIGhlbHBlciBmdW5jdGlvbiBpbnZvY2F0aW9uXG4gKiBAcGFyYW0ge3N0cmluZ30gY21kIE9yaWdpbmFsIGNvbW1hbmQgdG8gZXhlY3V0ZVxuICogQHBhcmFtIHtzdHJpbmd8VVJMP30gW2N3ZF0gT3B0aW9uYWwgcGF0aCB0byB0aGUgY3VycmVudCB3b3JraW5nIGRpclxuICogQHJldHVybnMge05vZGVKUy5FcnJub0V4Y2VwdGlvbn0gTXV0YXRlZCBlcnJvciBpbnN0YW5jZSB3aXRoIGFuIGltcHJvdmVkIGRlc2NyaXB0aW9uIG9yIGFuXG4gKiB1bmNoYW5nZWQgZXJyb3IgaW5zdGFuY2VcbiAqL1xuZnVuY3Rpb24gZm9ybWF0RW5vZW50IChlcnJvciwgY21kLCBjd2QgPSBudWxsKSB7XG4gIHRyeSB7XG4gICAgd2hpY2guc3luYyhjbWQpO1xuICAgIGlmIChjd2QpIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIGZzLmFjY2Vzc1N5bmMoY3dkLCBmcy5SX09LKTtcbiAgICAgIH0gY2F0Y2ggKGlnbikge1xuICAgICAgICBlcnJvci5tZXNzYWdlID0gYFRoZSBjdXJyZW50IHdvcmtpbmcgZGlyZWN0b3J5ICcke2N3ZH0nIGZvciAnJHtjbWR9JyBjb21tYW5kIGAgK1xuICAgICAgICAgIGBlaXRoZXIgZG9lcyBub3QgZXhpc3Qgb3IgaXMgbm90IGFjY2Vzc2libGVgO1xuICAgICAgfVxuICAgIH1cbiAgfSBjYXRjaCAoaWduKSB7XG4gICAgZXJyb3IubWVzc2FnZSA9IGBDb21tYW5kICcke2NtZH0nIG5vdCBmb3VuZC4gSXMgaXQgaW5zdGFsbGVkP2A7XG4gIH1cbiAgcmV0dXJuIGVycm9yO1xufVxuXG5leHBvcnQgeyBmb3JtYXRFbm9lbnQgfTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFhQSxTQUFTQSxZQUFULENBQXVCQyxLQUF2QixFQUE4QkMsR0FBOUIsRUFBbUNDLEdBQUcsR0FBRyxJQUF6QyxFQUErQztFQUM3QyxJQUFJO0lBQ0ZDLGNBQUEsQ0FBTUMsSUFBTixDQUFXSCxHQUFYOztJQUNBLElBQUlDLEdBQUosRUFBUztNQUNQLElBQUk7UUFDRkcsV0FBQSxDQUFHQyxVQUFILENBQWNKLEdBQWQsRUFBbUJHLFdBQUEsQ0FBR0UsSUFBdEI7TUFDRCxDQUZELENBRUUsT0FBT0MsR0FBUCxFQUFZO1FBQ1pSLEtBQUssQ0FBQ1MsT0FBTixHQUFpQixrQ0FBaUNQLEdBQUksVUFBU0QsR0FBSSxZQUFuRCxHQUNiLDRDQURIO01BRUQ7SUFDRjtFQUNGLENBVkQsQ0FVRSxPQUFPTyxHQUFQLEVBQVk7SUFDWlIsS0FBSyxDQUFDUyxPQUFOLEdBQWlCLFlBQVdSLEdBQUksK0JBQWhDO0VBQ0Q7O0VBQ0QsT0FBT0QsS0FBUDtBQUNEIn0=
32
+ }
33
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmb3JtYXRFbm9lbnQiLCJlcnJvciIsImNtZCIsImN3ZCIsIndoaWNoIiwic3luYyIsImZzIiwiYWNjZXNzU3luYyIsImNvbnN0YW50cyIsIlJfT0siLCJpZ24iLCJtZXNzYWdlIl0sInNvdXJjZXMiOlsiLi4vLi4vbGliL2hlbHBlcnMuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHdoaWNoIGZyb20gJ3doaWNoJztcbmltcG9ydCBmcyBmcm9tICdmcyc7XG5cbi8qKlxuICogRGVjb3JhdGVzIEVOT0VOVCBlcnJvciByZWNlaXZlZCBmcm9tIGEgc3Bhd24gc3lzdGVtIGNhbGxcbiAqIHdpdGggYSBtb3JlIGRlc2NyaXB0aXZlIG1lc3NhZ2UsIHNvIGl0IGNvdWxkIGJlIHByb3Blcmx5IGhhbmRsZWQgYnkgYSB1c2VyLlxuICpcbiAqIEBwYXJhbSB7Tm9kZUpTLkVycm5vRXhjZXB0aW9ufSBlcnJvciBPcmlnaW5hbCBlcnJvciBpbnN0YW5jZS4gISEhIFRoZSBpbnN0YW5jZSBpcyBtdXRhdGVkIGFmdGVyXG4gKiB0aGlzIGhlbHBlciBmdW5jdGlvbiBpbnZvY2F0aW9uXG4gKiBAcGFyYW0ge3N0cmluZ30gY21kIE9yaWdpbmFsIGNvbW1hbmQgdG8gZXhlY3V0ZVxuICogQHBhcmFtIHtzdHJpbmd8VVJMP30gW2N3ZF0gT3B0aW9uYWwgcGF0aCB0byB0aGUgY3VycmVudCB3b3JraW5nIGRpclxuICogQHJldHVybnMge05vZGVKUy5FcnJub0V4Y2VwdGlvbn0gTXV0YXRlZCBlcnJvciBpbnN0YW5jZSB3aXRoIGFuIGltcHJvdmVkIGRlc2NyaXB0aW9uIG9yIGFuXG4gKiB1bmNoYW5nZWQgZXJyb3IgaW5zdGFuY2VcbiAqL1xuZnVuY3Rpb24gZm9ybWF0RW5vZW50IChlcnJvciwgY21kLCBjd2QgPSBudWxsKSB7XG4gIHRyeSB7XG4gICAgd2hpY2guc3luYyhjbWQpO1xuICAgIGlmIChjd2QpIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIGZzLmFjY2Vzc1N5bmMoY3dkLCBmcy5jb25zdGFudHMuUl9PSyk7XG4gICAgICB9IGNhdGNoIChpZ24pIHtcbiAgICAgICAgZXJyb3IubWVzc2FnZSA9IGBUaGUgY3VycmVudCB3b3JraW5nIGRpcmVjdG9yeSAnJHtjd2R9JyBmb3IgJyR7Y21kfScgY29tbWFuZCBgICtcbiAgICAgICAgICBgZWl0aGVyIGRvZXMgbm90IGV4aXN0IG9yIGlzIG5vdCBhY2Nlc3NpYmxlYDtcbiAgICAgIH1cbiAgICB9XG4gIH0gY2F0Y2ggKGlnbikge1xuICAgIGVycm9yLm1lc3NhZ2UgPSBgQ29tbWFuZCAnJHtjbWR9JyBub3QgZm91bmQuIElzIGl0IGluc3RhbGxlZD9gO1xuICB9XG4gIHJldHVybiBlcnJvcjtcbn1cblxuZXhwb3J0IHsgZm9ybWF0RW5vZW50IH07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FBQUE7O0FBQ0E7O0FBYUEsU0FBU0EsWUFBVCxDQUF1QkMsS0FBdkIsRUFBOEJDLEdBQTlCLEVBQW1DQyxHQUFHLEdBQUcsSUFBekMsRUFBK0M7RUFDN0MsSUFBSTtJQUNGQyxjQUFBLENBQU1DLElBQU4sQ0FBV0gsR0FBWDs7SUFDQSxJQUFJQyxHQUFKLEVBQVM7TUFDUCxJQUFJO1FBQ0ZHLFdBQUEsQ0FBR0MsVUFBSCxDQUFjSixHQUFkLEVBQW1CRyxXQUFBLENBQUdFLFNBQUgsQ0FBYUMsSUFBaEM7TUFDRCxDQUZELENBRUUsT0FBT0MsR0FBUCxFQUFZO1FBQ1pULEtBQUssQ0FBQ1UsT0FBTixHQUFpQixrQ0FBaUNSLEdBQUksVUFBU0QsR0FBSSxZQUFuRCxHQUNiLDRDQURIO01BRUQ7SUFDRjtFQUNGLENBVkQsQ0FVRSxPQUFPUSxHQUFQLEVBQVk7SUFDWlQsS0FBSyxDQUFDVSxPQUFOLEdBQWlCLFlBQVdULEdBQUksK0JBQWhDO0VBQ0Q7O0VBQ0QsT0FBT0QsS0FBUDtBQUNEIn0=
@@ -28,7 +28,5 @@ exports.SubProcess = SubProcess;
28
28
  const {
29
29
  exec
30
30
  } = execIndex;
31
- exports.exec = exec;require('source-map-support').install();
32
-
33
-
34
- //# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGliL2luZGV4LmpzIiwibmFtZXMiOlsic3Bhd24iLCJjcCIsIlN1YlByb2Nlc3MiLCJzcEluZGV4IiwiZXhlYyIsImV4ZWNJbmRleCJdLCJzb3VyY2VSb290IjoiLi4vLi4iLCJzb3VyY2VzIjpbImxpYi9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyB0cmFuc3BpbGU6bWFpblxuaW1wb3J0ICogYXMgY3AgZnJvbSAnY2hpbGRfcHJvY2Vzcyc7XG5pbXBvcnQgKiBhcyBzcEluZGV4IGZyb20gJy4vc3VicHJvY2Vzcyc7XG5pbXBvcnQgKiBhcyBleGVjSW5kZXggZnJvbSAnLi9leGVjJztcblxuXG5jb25zdCB7IHNwYXduIH0gPSBjcDtcbmNvbnN0IHsgU3ViUHJvY2VzcyB9ID0gc3BJbmRleDtcbmNvbnN0IHsgZXhlYyB9ID0gZXhlY0luZGV4O1xuXG5leHBvcnQgeyBleGVjLCBzcGF3biwgU3ViUHJvY2VzcyB9O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFDQTs7QUFDQTs7QUFDQTs7Ozs7O0FBR0EsTUFBTTtFQUFFQTtBQUFGLElBQVlDLEVBQWxCOztBQUNBLE1BQU07RUFBRUM7QUFBRixJQUFpQkMsT0FBdkI7O0FBQ0EsTUFBTTtFQUFFQztBQUFGLElBQVdDLFNBQWpCIn0=
31
+ exports.exec = exec;
32
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzcGF3biIsImNwIiwiU3ViUHJvY2VzcyIsInNwSW5kZXgiLCJleGVjIiwiZXhlY0luZGV4Il0sInNvdXJjZXMiOlsiLi4vLi4vbGliL2luZGV4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIHRyYW5zcGlsZTptYWluXG5pbXBvcnQgKiBhcyBjcCBmcm9tICdjaGlsZF9wcm9jZXNzJztcbmltcG9ydCAqIGFzIHNwSW5kZXggZnJvbSAnLi9zdWJwcm9jZXNzJztcbmltcG9ydCAqIGFzIGV4ZWNJbmRleCBmcm9tICcuL2V4ZWMnO1xuXG5cbmNvbnN0IHsgc3Bhd24gfSA9IGNwO1xuY29uc3QgeyBTdWJQcm9jZXNzIH0gPSBzcEluZGV4O1xuY29uc3QgeyBleGVjIH0gPSBleGVjSW5kZXg7XG5cbmV4cG9ydCB7IGV4ZWMsIHNwYXduLCBTdWJQcm9jZXNzIH07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUNBOztBQUNBOztBQUNBOzs7Ozs7QUFHQSxNQUFNO0VBQUVBO0FBQUYsSUFBWUMsRUFBbEI7O0FBQ0EsTUFBTTtFQUFFQztBQUFGLElBQWlCQyxPQUF2Qjs7QUFDQSxNQUFNO0VBQUVDO0FBQUYsSUFBV0MsU0FBakIifQ==
@@ -31,6 +31,14 @@ function cutSuffix(str, suffixLength) {
31
31
  }
32
32
 
33
33
  class SubProcess extends EventEmitter {
34
+ lastLinePortion;
35
+ proc;
36
+ args;
37
+ cmd;
38
+ opts;
39
+ expectingExit;
40
+ rep;
41
+
34
42
  constructor(cmd, args = [], opts = {}) {
35
43
  super();
36
44
  if (!cmd) throw new Error('Command is required');
@@ -42,6 +50,10 @@ class SubProcess extends EventEmitter {
42
50
  this.opts = opts;
43
51
  this.expectingExit = false;
44
52
  this.rep = (0, _shellQuote.quote)([cmd, ...args]);
53
+ this.lastLinePortion = {
54
+ stdout: '',
55
+ stderr: ''
56
+ };
45
57
  }
46
58
 
47
59
  get isRunning() {
@@ -109,7 +121,7 @@ class SubProcess extends EventEmitter {
109
121
  } = streams;
110
122
 
111
123
  try {
112
- if (startDetector && startDetector(stdout, stderr)) {
124
+ if (_lodash.default.isFunction(startDetector) && startDetector(stdout, stderr)) {
113
125
  startDetector = null;
114
126
  resolve();
115
127
  }
@@ -142,17 +154,19 @@ class SubProcess extends EventEmitter {
142
154
  };
143
155
 
144
156
  this.proc.on('error', err => {
145
- this.proc.removeAllListeners('exit');
146
- this.proc.kill('SIGINT');
157
+ var _this$proc, _this$proc2, _this$proc3;
147
158
 
148
- if (err.errno === 'ENOENT') {
159
+ (_this$proc = this.proc) === null || _this$proc === void 0 ? void 0 : _this$proc.removeAllListeners('exit');
160
+ (_this$proc2 = this.proc) === null || _this$proc2 === void 0 ? void 0 : _this$proc2.kill('SIGINT');
161
+
162
+ if (err.code === 'ENOENT') {
149
163
  var _this$opts;
150
164
 
151
165
  err = (0, _helpers.formatEnoent)(err, this.cmd, (_this$opts = this.opts) === null || _this$opts === void 0 ? void 0 : _this$opts.cwd);
152
166
  }
153
167
 
154
168
  reject(err);
155
- this.proc.unref();
169
+ (_this$proc3 = this.proc) === null || _this$proc3 === void 0 ? void 0 : _this$proc3.unref();
156
170
  this.proc = null;
157
171
  });
158
172
 
@@ -220,9 +234,11 @@ class SubProcess extends EventEmitter {
220
234
 
221
235
  this.handleLastLines();
222
236
  return await new _bluebird.default((resolve, reject) => {
223
- this.proc.on('close', resolve);
237
+ var _this$proc4, _this$proc5;
238
+
239
+ (_this$proc4 = this.proc) === null || _this$proc4 === void 0 ? void 0 : _this$proc4.on('close', resolve);
224
240
  this.expectingExit = true;
225
- this.proc.kill(signal);
241
+ (_this$proc5 = this.proc) === null || _this$proc5 === void 0 ? void 0 : _this$proc5.kill(signal);
226
242
  setTimeout(() => {
227
243
  reject(new Error(`Process didn't end after ${timeout}ms (cmd: '${this.rep}')`));
228
244
  }, timeout).unref();
@@ -235,8 +251,10 @@ class SubProcess extends EventEmitter {
235
251
  }
236
252
 
237
253
  return await new _bluebird.default((resolve, reject) => {
238
- this.proc.on('exit', code => {
239
- if (allowedExitCodes.indexOf(code) === -1) {
254
+ var _this$proc6;
255
+
256
+ (_this$proc6 = this.proc) === null || _this$proc6 === void 0 ? void 0 : _this$proc6.on('exit', code => {
257
+ if (code !== null && allowedExitCodes.indexOf(code) === -1) {
240
258
  reject(new Error(`Process ended with exitcode ${code} (cmd: '${this.rep}')`));
241
259
  } else {
242
260
  resolve(code);
@@ -263,7 +281,5 @@ class SubProcess extends EventEmitter {
263
281
 
264
282
  exports.SubProcess = SubProcess;
265
283
  var _default = SubProcess;
266
- exports.default = _default;require('source-map-support').install();
267
-
268
-
269
- //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"file":"lib/subprocess.js","names":["EventEmitter","events","MAX_LINE_PORTION_LENGTH","cutSuffix","str","suffixLength","length","substr","SubProcess","constructor","cmd","args","opts","Error","_","isString","isArray","proc","expectingExit","rep","quote","isRunning","emitLines","stream","lines","line","emit","toUpperCase","start","startDetector","timeoutMs","detach","startDelay","genericStartDetector","stdout","stderr","isNumber","isBoolean","detached","B","resolve","reject","spawn","setEncoding","encoding","lastLinePortion","handleOutput","streams","e","streamName","streamData","toPairs","split","map","x","last","resultLines","slice","currentPortion","on","err","removeAllListeners","kill","errno","formatEnoent","cwd","unref","chunk","toString","code","signal","handleLastLines","event","setTimeout","finally","lastLines","stop","timeout","join","allowedExitCodes","indexOf","detachProcess","pid"],"sourceRoot":"../..","sources":["lib/subprocess.js"],"sourcesContent":["/* eslint-disable promise/prefer-await-to-callbacks */\n\nimport { spawn } from 'child_process';\nimport events from 'events';\nconst { EventEmitter } = events;\nimport B from 'bluebird';\nimport { quote } from 'shell-quote';\nimport _ from 'lodash';\nimport { formatEnoent } from './helpers';\n\n\n// This is needed to avoid memory leaks\n// when the process output is too long and contains\n// no line breaks\nconst MAX_LINE_PORTION_LENGTH = 0xFFFF;\n\nfunction cutSuffix (str, suffixLength) {\n  return str.length > suffixLength\n    // https://bugs.chromium.org/p/v8/issues/detail?id=2869\n    ? ` ${str.substr(str.length - suffixLength)}`.substr(1)\n    : str;\n}\n\n\nclass SubProcess extends EventEmitter {\n  constructor (cmd, args = [], opts = {}) {\n    super();\n    if (!cmd) throw new Error('Command is required'); // eslint-disable-line curly\n    if (!_.isString(cmd)) throw new Error('Command must be a string'); // eslint-disable-line curly\n    if (!_.isArray(args)) throw new Error('Args must be an array'); // eslint-disable-line curly\n\n    this.cmd = cmd;\n    this.args = args;\n    this.proc = null;\n    this.opts = opts;\n    this.expectingExit = false;\n\n    // get a quoted representation of the command for error strings\n    this.rep = quote([cmd, ...args]);\n  }\n\n  get isRunning () {\n    // presence of `proc` means we have connected and started\n    return !!this.proc;\n  }\n\n  emitLines (stream, lines) {\n    for (let line of lines) {\n      this.emit('stream-line', `[${stream.toUpperCase()}] ${line}`);\n    }\n  }\n\n  // spawn the subprocess and return control whenever we deem that it has fully\n  // \"started\"\n  async start (startDetector = null, timeoutMs = null, detach = false) {\n    let startDelay = 10;\n\n    const genericStartDetector = function genericStartDetector (stdout, stderr) {\n      return stdout || stderr;\n    };\n\n    // the default start detector simply returns true when we get any output\n    if (startDetector === null) {\n      startDetector = genericStartDetector;\n    }\n\n    // if the user passes a number, then we simply delay a certain amount of\n    // time before returning control, rather than waiting for a condition\n    if (_.isNumber(startDetector)) {\n      startDelay = startDetector;\n      startDetector = null;\n    }\n\n    // if the user passes in a boolean as one of the arguments, use it for `detach`\n    if (_.isBoolean(startDetector) && startDetector) {\n      if (!this.opts.detached) {\n        throw new Error(`Unable to detach process that is not started with 'detached' option`);\n      }\n      detach = true;\n      startDetector = genericStartDetector;\n    } else if (_.isBoolean(timeoutMs) && timeoutMs) {\n      if (!this.opts.detached) {\n        throw new Error(`Unable to detach process that is not started with 'detached' option`);\n      }\n      detach = true;\n      timeoutMs = null;\n    }\n\n    // return a promise so we can wrap the async behavior\n    return await new B((resolve, reject) => {\n      // actually spawn the subproc\n      this.proc = spawn(this.cmd, this.args, this.opts);\n\n      if (this.proc.stdout) {\n        this.proc.stdout.setEncoding(this.opts.encoding || 'utf8');\n      }\n      if (this.proc.stderr) {\n        this.proc.stderr.setEncoding(this.opts.encoding || 'utf8');\n      }\n      this.lastLinePortion = {stdout: '', stderr: ''};\n\n      // this function handles output that we collect from the subproc\n      const handleOutput = (streams) => {\n        const {stdout, stderr} = streams;\n        // if we have a startDetector, run it on the output so we can resolve/\n        // reject and move on from start\n        try {\n          if (startDetector && startDetector(stdout, stderr)) {\n            startDetector = null;\n            resolve();\n          }\n        } catch (e) {\n          reject(e);\n        }\n\n        // emit the actual output for whomever's listening\n        this.emit('output', stdout, stderr);\n\n        // we also want to emit lines, but it's more complex since output\n        // comes in chunks and a line could come in two different chunks, so\n        // we have logic to handle that case (using this.lastLinePortion to\n        // remember a line that started but did not finish in the last chunk)\n        for (const [streamName, streamData] of _.toPairs(streams)) {\n          if (!streamData) continue; // eslint-disable-line curly\n          const lines = streamData.split('\\n')\n            // https://bugs.chromium.org/p/v8/issues/detail?id=2869\n            .map((x) => ` ${x}`.substr(1));\n          if (lines.length > 1) {\n            lines[0] = this.lastLinePortion[streamName] + lines[0];\n            this.lastLinePortion[streamName] = cutSuffix(_.last(lines), MAX_LINE_PORTION_LENGTH);\n            const resultLines = lines.slice(0, -1);\n            this.emit(`lines-${streamName}`, resultLines);\n            this.emitLines(streamName, resultLines);\n          } else {\n            const currentPortion = cutSuffix(lines[0], MAX_LINE_PORTION_LENGTH);\n            if (this.lastLinePortion[streamName].length + currentPortion.length > MAX_LINE_PORTION_LENGTH) {\n              this.lastLinePortion[streamName] = currentPortion;\n            } else {\n              this.lastLinePortion[streamName] += currentPortion;\n            }\n          }\n        }\n      };\n\n      // if we get an error spawning the proc, reject and clean up the proc\n      this.proc.on('error', (err) => {\n        this.proc.removeAllListeners('exit');\n        this.proc.kill('SIGINT');\n\n        if (err.errno === 'ENOENT') {\n          err = formatEnoent(err, this.cmd, this.opts?.cwd);\n        }\n        reject(err);\n\n        this.proc.unref();\n        this.proc = null;\n      });\n\n      if (this.proc.stdout) {\n        this.proc.stdout.on('data', (chunk) => handleOutput({stdout: chunk.toString(), stderr: ''}));\n      }\n\n      if (this.proc.stderr) {\n        this.proc.stderr.on('data', (chunk) => handleOutput({stdout: '', stderr: chunk.toString()}));\n      }\n\n      // when the proc exits, we might still have a buffer of lines we were\n      // waiting on more chunks to complete. Go ahead and emit those, then\n      // re-emit the exit so a listener can handle the possibly-unexpected exit\n      this.proc.on('exit', (code, signal) => {\n        this.handleLastLines();\n\n        this.emit('exit', code, signal);\n\n        // in addition to the bare exit event, also emit one of three other\n        // events that contain more helpful information:\n        // 'stop': we stopped this\n        // 'die': the process ended out of our control with a non-zero exit\n        // 'end': the process ended out of our control with a zero exit\n        let event = this.expectingExit ? 'stop' : 'die';\n        if (!this.expectingExit && code === 0) {\n          event = 'end';\n        }\n        this.emit(event, code, signal);\n\n        // finally clean up the proc and make sure to reset our exit\n        // expectations\n        this.proc = null;\n        this.expectingExit = false;\n      });\n\n      // if the user hasn't given us a startDetector, instead just resolve\n      // when startDelay ms have passed\n      if (!startDetector) {\n        setTimeout(() => { resolve(); }, startDelay);\n      }\n\n      // if the user has given us a timeout, start the clock for rejecting\n      // the promise if we take too long to start\n      if (_.isNumber(timeoutMs)) {\n        setTimeout(() => {\n          reject(new Error(`The process did not start within ${timeoutMs}ms ` +\n            `(cmd: '${this.rep}')`));\n        }, timeoutMs);\n      }\n    }).finally(() => {\n      if (detach && this.proc) {\n        this.proc.unref();\n      }\n    });\n  }\n\n  handleLastLines () {\n    for (let stream of ['stdout', 'stderr']) {\n      if (this.lastLinePortion[stream]) {\n        const lastLines = [this.lastLinePortion[stream]];\n        this.emit(`lines-${stream}`, lastLines);\n        this.emitLines(stream, lastLines);\n        this.lastLinePortion[stream] = '';\n      }\n    }\n  }\n\n  async stop (signal = 'SIGTERM', timeout = 10000) {\n    if (!this.isRunning) {\n      throw new Error(`Can't stop process; it's not currently running (cmd: '${this.rep}')`);\n    }\n    // make sure to emit any data in our lines buffer whenever we're done with\n    // the proc\n    this.handleLastLines();\n    return await new B((resolve, reject) => {\n      this.proc.on('close', resolve);\n      this.expectingExit = true;\n      this.proc.kill(signal);\n      // this timeout needs unref() or node will wait for the timeout to fire before\n      // exiting the process.\n      setTimeout(() => {\n        reject(new Error(`Process didn't end after ${timeout}ms (cmd: '${this.rep}')`));\n      }, timeout).unref();\n    });\n  }\n\n  async join (allowedExitCodes = [0]) {\n    if (!this.isRunning) {\n      throw new Error(`Cannot join process; it is not currently running (cmd: '${this.rep}')`);\n    }\n\n    return await new B((resolve, reject) => {\n      this.proc.on('exit', (code) => {\n        if (allowedExitCodes.indexOf(code) === -1) {\n          reject(new Error(`Process ended with exitcode ${code} (cmd: '${this.rep}')`));\n        } else {\n          resolve(code);\n        }\n      });\n    });\n  }\n\n  /*\n   * This will only work if the process is created with the `detached` option\n   */\n  detachProcess () {\n    if (!this.opts.detached) {\n      // this means that there is a misconfiguration in the calling code\n      throw new Error(`Unable to detach process that is not started with 'detached' option`);\n    }\n    if (this.proc) {\n      this.proc.unref();\n    }\n  }\n\n  get pid () {\n    return this.proc ? this.proc.pid : null;\n  }\n}\n\nexport { SubProcess };\nexport default SubProcess;\n"],"mappings":"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"}
284
+ exports.default = _default;
285
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["EventEmitter","events","MAX_LINE_PORTION_LENGTH","cutSuffix","str","suffixLength","length","substr","SubProcess","lastLinePortion","proc","args","cmd","opts","expectingExit","rep","constructor","Error","_","isString","isArray","quote","stdout","stderr","isRunning","emitLines","stream","lines","line","emit","toUpperCase","start","startDetector","timeoutMs","detach","startDelay","genericStartDetector","isNumber","isBoolean","detached","B","resolve","reject","spawn","setEncoding","encoding","handleOutput","streams","isFunction","e","streamName","streamData","toPairs","split","map","x","last","resultLines","slice","currentPortion","on","err","removeAllListeners","kill","code","formatEnoent","cwd","unref","chunk","toString","signal","handleLastLines","event","setTimeout","finally","lastLines","stop","timeout","join","allowedExitCodes","indexOf","detachProcess","pid"],"sources":["../../lib/subprocess.js"],"sourcesContent":["/* eslint-disable promise/prefer-await-to-callbacks */\n\nimport { spawn } from 'child_process';\nimport events from 'events';\nconst { EventEmitter } = events;\nimport B from 'bluebird';\nimport { quote } from 'shell-quote';\nimport _ from 'lodash';\nimport { formatEnoent } from './helpers';\n\n\n// This is needed to avoid memory leaks\n// when the process output is too long and contains\n// no line breaks\nconst MAX_LINE_PORTION_LENGTH = 0xFFFF;\n\nfunction cutSuffix (str, suffixLength) {\n  return str.length > suffixLength\n    // https://bugs.chromium.org/p/v8/issues/detail?id=2869\n    ? ` ${str.substr(str.length - suffixLength)}`.substr(1)\n    : str;\n}\n\n\nclass SubProcess extends EventEmitter {\n\n  /**\n   * @type { {stdout: string, stderr: string} }\n   */\n  lastLinePortion;\n\n  /** @type {import('child_process').ChildProcess?} */\n  proc;\n\n  /** @type {string[]} */\n  args;\n\n  /**\n   * @type {string}\n   */\n  cmd;\n\n  /**\n   * @type {any}\n  */\n  opts;\n\n  /**\n   * @type {boolean}\n   */\n  expectingExit;\n\n  /**\n   * @type {string}\n   */\n  rep;\n\n  /**\n   * @param {string} cmd\n   * @param {string[]} [args]\n   * @param {any} [opts]\n   */\n  constructor (cmd, args = [], opts = {}) {\n    super();\n    if (!cmd) throw new Error('Command is required'); // eslint-disable-line curly\n    if (!_.isString(cmd)) throw new Error('Command must be a string'); // eslint-disable-line curly\n    if (!_.isArray(args)) throw new Error('Args must be an array'); // eslint-disable-line curly\n\n    this.cmd = cmd;\n    this.args = args;\n    this.proc = null;\n    this.opts = opts;\n    this.expectingExit = false;\n\n    // get a quoted representation of the command for error strings\n    this.rep = quote([cmd, ...args]);\n\n    this.lastLinePortion = {stdout: '', stderr: ''};\n  }\n\n  get isRunning () {\n    // presence of `proc` means we have connected and started\n    return !!this.proc;\n  }\n\n  /**\n   *\n   * @param {string} stream\n   * @param {Iterable<string>} lines\n   */\n  emitLines (stream, lines) {\n    for (let line of lines) {\n      this.emit('stream-line', `[${stream.toUpperCase()}] ${line}`);\n    }\n  }\n\n  // spawn the subprocess and return control whenever we deem that it has fully\n  // \"started\"\n  /**\n   *\n   * @param {StartDetector|number?} startDetector\n   * @param {number?} timeoutMs\n   * @param {boolean} detach\n   * @returns {Promise<void>}\n   */\n  async start (startDetector = null, timeoutMs = null, detach = false) {\n    let startDelay = 10;\n\n    const genericStartDetector = /** @type {StartDetector} */(function genericStartDetector (stdout, stderr) {\n      return stdout || stderr;\n    });\n\n    // the default start detector simply returns true when we get any output\n    if (startDetector === null) {\n      startDetector = genericStartDetector;\n    }\n\n    // if the user passes a number, then we simply delay a certain amount of\n    // time before returning control, rather than waiting for a condition\n    if (_.isNumber(startDetector)) {\n      startDelay = startDetector;\n      startDetector = null;\n    }\n\n    // if the user passes in a boolean as one of the arguments, use it for `detach`\n    if (_.isBoolean(startDetector) && startDetector) {\n      if (!this.opts.detached) {\n        throw new Error(`Unable to detach process that is not started with 'detached' option`);\n      }\n      detach = true;\n      startDetector = genericStartDetector;\n    } else if (_.isBoolean(timeoutMs) && timeoutMs) {\n      if (!this.opts.detached) {\n        throw new Error(`Unable to detach process that is not started with 'detached' option`);\n      }\n      detach = true;\n      timeoutMs = null;\n    }\n\n    // return a promise so we can wrap the async behavior\n    return await new B((resolve, reject) => {\n      // actually spawn the subproc\n      this.proc = spawn(this.cmd, this.args, this.opts);\n\n      if (this.proc.stdout) {\n        this.proc.stdout.setEncoding(this.opts.encoding || 'utf8');\n      }\n      if (this.proc.stderr) {\n        this.proc.stderr.setEncoding(this.opts.encoding || 'utf8');\n      }\n      this.lastLinePortion = {stdout: '', stderr: ''};\n\n      // this function handles output that we collect from the subproc\n      /**\n       *\n       * @param { {stdout: string, stderr: string} } streams\n       */\n      const handleOutput = (streams) => {\n        const {stdout, stderr} = streams;\n        // if we have a startDetector, run it on the output so we can resolve/\n        // reject and move on from start\n        try {\n          if (_.isFunction(startDetector) && startDetector(stdout, stderr)) {\n            startDetector = null;\n            resolve();\n          }\n        } catch (e) {\n          reject(e);\n        }\n\n        // emit the actual output for whomever's listening\n        this.emit('output', stdout, stderr);\n\n        // we also want to emit lines, but it's more complex since output\n        // comes in chunks and a line could come in two different chunks, so\n        // we have logic to handle that case (using this.lastLinePortion to\n        // remember a line that started but did not finish in the last chunk)\n        for (const [streamName, streamData] of /** @type {[['stdout', string], ['stderr', string]]} */(_.toPairs(streams))) {\n          if (!streamData) continue; // eslint-disable-line curly\n          const lines = streamData.split('\\n')\n            // https://bugs.chromium.org/p/v8/issues/detail?id=2869\n            .map((x) => ` ${x}`.substr(1));\n          if (lines.length > 1) {\n            lines[0] = this.lastLinePortion[streamName] + lines[0];\n            this.lastLinePortion[streamName] = cutSuffix(_.last(lines), MAX_LINE_PORTION_LENGTH);\n            const resultLines = lines.slice(0, -1);\n            this.emit(`lines-${streamName}`, resultLines);\n            this.emitLines(streamName, resultLines);\n          } else {\n            const currentPortion = cutSuffix(lines[0], MAX_LINE_PORTION_LENGTH);\n            if (this.lastLinePortion[streamName].length + currentPortion.length > MAX_LINE_PORTION_LENGTH) {\n              this.lastLinePortion[streamName] = currentPortion;\n            } else {\n              this.lastLinePortion[streamName] += currentPortion;\n            }\n          }\n        }\n      };\n\n      // if we get an error spawning the proc, reject and clean up the proc\n      this.proc.on('error', /** @param {NodeJS.ErrnoException} err */ (err) => {\n        this.proc?.removeAllListeners('exit');\n        this.proc?.kill('SIGINT');\n\n        if (err.code === 'ENOENT') {\n          err = formatEnoent(err, this.cmd, this.opts?.cwd);\n        }\n        reject(err);\n\n        this.proc?.unref();\n        this.proc = null;\n      });\n\n      if (this.proc.stdout) {\n        this.proc.stdout.on('data', (chunk) => handleOutput({stdout: chunk.toString(), stderr: ''}));\n      }\n\n      if (this.proc.stderr) {\n        this.proc.stderr.on('data', (chunk) => handleOutput({stdout: '', stderr: chunk.toString()}));\n      }\n\n      // when the proc exits, we might still have a buffer of lines we were\n      // waiting on more chunks to complete. Go ahead and emit those, then\n      // re-emit the exit so a listener can handle the possibly-unexpected exit\n      this.proc.on('exit', (code, signal) => {\n        this.handleLastLines();\n\n        this.emit('exit', code, signal);\n\n        // in addition to the bare exit event, also emit one of three other\n        // events that contain more helpful information:\n        // 'stop': we stopped this\n        // 'die': the process ended out of our control with a non-zero exit\n        // 'end': the process ended out of our control with a zero exit\n        let event = this.expectingExit ? 'stop' : 'die';\n        if (!this.expectingExit && code === 0) {\n          event = 'end';\n        }\n        this.emit(event, code, signal);\n\n        // finally clean up the proc and make sure to reset our exit\n        // expectations\n        this.proc = null;\n        this.expectingExit = false;\n      });\n\n      // if the user hasn't given us a startDetector, instead just resolve\n      // when startDelay ms have passed\n      if (!startDetector) {\n        setTimeout(() => { resolve(); }, startDelay);\n      }\n\n      // if the user has given us a timeout, start the clock for rejecting\n      // the promise if we take too long to start\n      if (_.isNumber(timeoutMs)) {\n        setTimeout(() => {\n          reject(new Error(`The process did not start within ${timeoutMs}ms ` +\n            `(cmd: '${this.rep}')`));\n        }, timeoutMs);\n      }\n    }).finally(() => {\n      if (detach && this.proc) {\n        this.proc.unref();\n      }\n    });\n  }\n\n  handleLastLines () {\n    for (let stream of ['stdout', 'stderr']) {\n      if (this.lastLinePortion[stream]) {\n        const lastLines = [this.lastLinePortion[stream]];\n        this.emit(`lines-${stream}`, lastLines);\n        this.emitLines(stream, lastLines);\n        this.lastLinePortion[stream] = '';\n      }\n    }\n  }\n\n  /**\n   *\n   * @param {NodeJS.Signals} signal\n   * @param {number} timeout\n   * @returns {Promise<void>}\n   */\n  async stop (signal = 'SIGTERM', timeout = 10000) {\n    if (!this.isRunning) {\n      throw new Error(`Can't stop process; it's not currently running (cmd: '${this.rep}')`);\n    }\n    // make sure to emit any data in our lines buffer whenever we're done with\n    // the proc\n    this.handleLastLines();\n    return await new B((resolve, reject) => {\n      this.proc?.on('close', resolve);\n      this.expectingExit = true;\n      this.proc?.kill(signal);\n      // this timeout needs unref() or node will wait for the timeout to fire before\n      // exiting the process.\n      setTimeout(() => {\n        reject(new Error(`Process didn't end after ${timeout}ms (cmd: '${this.rep}')`));\n      }, timeout).unref();\n    });\n  }\n\n  async join (allowedExitCodes = [0]) {\n    if (!this.isRunning) {\n      throw new Error(`Cannot join process; it is not currently running (cmd: '${this.rep}')`);\n    }\n\n    return await new B((resolve, reject) => {\n      this.proc?.on('exit', (code) => {\n        if (code !== null && allowedExitCodes.indexOf(code) === -1) {\n          reject(new Error(`Process ended with exitcode ${code} (cmd: '${this.rep}')`));\n        } else {\n          resolve(code);\n        }\n      });\n    });\n  }\n\n  /*\n   * This will only work if the process is created with the `detached` option\n   */\n  detachProcess () {\n    if (!this.opts.detached) {\n      // this means that there is a misconfiguration in the calling code\n      throw new Error(`Unable to detach process that is not started with 'detached' option`);\n    }\n    if (this.proc) {\n      this.proc.unref();\n    }\n  }\n\n  get pid () {\n    return this.proc ? this.proc.pid : null;\n  }\n}\n\nexport { SubProcess };\nexport default SubProcess;\n\n/**\n * @callback StartDetector\n * @param {string} stdout\n * @param {string} [stderr]\n * @returns {any}\n */\n"],"mappings":"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"}
package/lib/exec.js CHANGED
@@ -1,5 +1,3 @@
1
- // @ts-check
2
-
3
1
  /* eslint-disable promise/prefer-await-to-callbacks */
4
2
 
5
3
  import { spawn } from 'child_process';
@@ -24,7 +22,7 @@ async function exec (cmd, args = [], opts = /** @type {T} */({})) {
24
22
 
25
23
  // extend default options; we're basically re-implementing exec's options
26
24
  // for use here with spawn under the hood
27
- opts = Object.assign({
25
+ opts = /** @type {T} */(_.defaults(opts, {
28
26
  timeout: null,
29
27
  encoding: 'utf8',
30
28
  killSignal: 'SIGTERM',
@@ -37,7 +35,9 @@ async function exec (cmd, args = [], opts = /** @type {T} */({})) {
37
35
  logger: undefined,
38
36
  maxStdoutBufferSize: MAX_BUFFER_SIZE,
39
37
  maxStderrBufferSize: MAX_BUFFER_SIZE,
40
- }, opts);
38
+ }));
39
+
40
+ const isBuffer = Boolean(opts.isBuffer);
41
41
 
42
42
  // this is an async function, so return a promise
43
43
  return await new B((resolve, reject) => {
@@ -122,7 +122,7 @@ async function exec (cmd, args = [], opts = /** @type {T} */({})) {
122
122
  if (timer) {
123
123
  clearTimeout(timer);
124
124
  }
125
- let {stdout, stderr} = getStdio(opts.isBuffer);
125
+ let {stdout, stderr} = getStdio(isBuffer);
126
126
  if (code === 0) {
127
127
  resolve(/** @type {BufferProp<T> extends true ? TeenProcessExecBufferResult : TeenProcessExecStringResult} */({stdout, stderr, code}));
128
128
  } else {
@@ -137,7 +137,7 @@ async function exec (cmd, args = [], opts = /** @type {T} */({})) {
137
137
  // have in case it's helpful in debugging
138
138
  if (opts.timeout) {
139
139
  timer = setTimeout(() => {
140
- let {stdout, stderr} = getStdio(opts.isBuffer);
140
+ let {stdout, stderr} = getStdio(isBuffer);
141
141
  let err = new Error(`Command '${rep}' timed out after ${opts.timeout}ms`);
142
142
  err = Object.assign(err, {stdout, stderr, code: null});
143
143
  reject(err);
package/lib/helpers.js CHANGED
@@ -17,7 +17,7 @@ function formatEnoent (error, cmd, cwd = null) {
17
17
  which.sync(cmd);
18
18
  if (cwd) {
19
19
  try {
20
- fs.accessSync(cwd, fs.R_OK);
20
+ fs.accessSync(cwd, fs.constants.R_OK);
21
21
  } catch (ign) {
22
22
  error.message = `The current working directory '${cwd}' for '${cmd}' command ` +
23
23
  `either does not exist or is not accessible`;
package/lib/subprocess.js CHANGED
@@ -23,6 +23,43 @@ function cutSuffix (str, suffixLength) {
23
23
 
24
24
 
25
25
  class SubProcess extends EventEmitter {
26
+
27
+ /**
28
+ * @type { {stdout: string, stderr: string} }
29
+ */
30
+ lastLinePortion;
31
+
32
+ /** @type {import('child_process').ChildProcess?} */
33
+ proc;
34
+
35
+ /** @type {string[]} */
36
+ args;
37
+
38
+ /**
39
+ * @type {string}
40
+ */
41
+ cmd;
42
+
43
+ /**
44
+ * @type {any}
45
+ */
46
+ opts;
47
+
48
+ /**
49
+ * @type {boolean}
50
+ */
51
+ expectingExit;
52
+
53
+ /**
54
+ * @type {string}
55
+ */
56
+ rep;
57
+
58
+ /**
59
+ * @param {string} cmd
60
+ * @param {string[]} [args]
61
+ * @param {any} [opts]
62
+ */
26
63
  constructor (cmd, args = [], opts = {}) {
27
64
  super();
28
65
  if (!cmd) throw new Error('Command is required'); // eslint-disable-line curly
@@ -37,6 +74,8 @@ class SubProcess extends EventEmitter {
37
74
 
38
75
  // get a quoted representation of the command for error strings
39
76
  this.rep = quote([cmd, ...args]);
77
+
78
+ this.lastLinePortion = {stdout: '', stderr: ''};
40
79
  }
41
80
 
42
81
  get isRunning () {
@@ -44,6 +83,11 @@ class SubProcess extends EventEmitter {
44
83
  return !!this.proc;
45
84
  }
46
85
 
86
+ /**
87
+ *
88
+ * @param {string} stream
89
+ * @param {Iterable<string>} lines
90
+ */
47
91
  emitLines (stream, lines) {
48
92
  for (let line of lines) {
49
93
  this.emit('stream-line', `[${stream.toUpperCase()}] ${line}`);
@@ -52,12 +96,19 @@ class SubProcess extends EventEmitter {
52
96
 
53
97
  // spawn the subprocess and return control whenever we deem that it has fully
54
98
  // "started"
99
+ /**
100
+ *
101
+ * @param {StartDetector|number?} startDetector
102
+ * @param {number?} timeoutMs
103
+ * @param {boolean} detach
104
+ * @returns {Promise<void>}
105
+ */
55
106
  async start (startDetector = null, timeoutMs = null, detach = false) {
56
107
  let startDelay = 10;
57
108
 
58
- const genericStartDetector = function genericStartDetector (stdout, stderr) {
109
+ const genericStartDetector = /** @type {StartDetector} */(function genericStartDetector (stdout, stderr) {
59
110
  return stdout || stderr;
60
- };
111
+ });
61
112
 
62
113
  // the default start detector simply returns true when we get any output
63
114
  if (startDetector === null) {
@@ -100,12 +151,16 @@ class SubProcess extends EventEmitter {
100
151
  this.lastLinePortion = {stdout: '', stderr: ''};
101
152
 
102
153
  // this function handles output that we collect from the subproc
154
+ /**
155
+ *
156
+ * @param { {stdout: string, stderr: string} } streams
157
+ */
103
158
  const handleOutput = (streams) => {
104
159
  const {stdout, stderr} = streams;
105
160
  // if we have a startDetector, run it on the output so we can resolve/
106
161
  // reject and move on from start
107
162
  try {
108
- if (startDetector && startDetector(stdout, stderr)) {
163
+ if (_.isFunction(startDetector) && startDetector(stdout, stderr)) {
109
164
  startDetector = null;
110
165
  resolve();
111
166
  }
@@ -120,7 +175,7 @@ class SubProcess extends EventEmitter {
120
175
  // comes in chunks and a line could come in two different chunks, so
121
176
  // we have logic to handle that case (using this.lastLinePortion to
122
177
  // remember a line that started but did not finish in the last chunk)
123
- for (const [streamName, streamData] of _.toPairs(streams)) {
178
+ for (const [streamName, streamData] of /** @type {[['stdout', string], ['stderr', string]]} */(_.toPairs(streams))) {
124
179
  if (!streamData) continue; // eslint-disable-line curly
125
180
  const lines = streamData.split('\n')
126
181
  // https://bugs.chromium.org/p/v8/issues/detail?id=2869
@@ -143,16 +198,16 @@ class SubProcess extends EventEmitter {
143
198
  };
144
199
 
145
200
  // if we get an error spawning the proc, reject and clean up the proc
146
- this.proc.on('error', (err) => {
147
- this.proc.removeAllListeners('exit');
148
- this.proc.kill('SIGINT');
201
+ this.proc.on('error', /** @param {NodeJS.ErrnoException} err */ (err) => {
202
+ this.proc?.removeAllListeners('exit');
203
+ this.proc?.kill('SIGINT');
149
204
 
150
- if (err.errno === 'ENOENT') {
205
+ if (err.code === 'ENOENT') {
151
206
  err = formatEnoent(err, this.cmd, this.opts?.cwd);
152
207
  }
153
208
  reject(err);
154
209
 
155
- this.proc.unref();
210
+ this.proc?.unref();
156
211
  this.proc = null;
157
212
  });
158
213
 
@@ -221,6 +276,12 @@ class SubProcess extends EventEmitter {
221
276
  }
222
277
  }
223
278
 
279
+ /**
280
+ *
281
+ * @param {NodeJS.Signals} signal
282
+ * @param {number} timeout
283
+ * @returns {Promise<void>}
284
+ */
224
285
  async stop (signal = 'SIGTERM', timeout = 10000) {
225
286
  if (!this.isRunning) {
226
287
  throw new Error(`Can't stop process; it's not currently running (cmd: '${this.rep}')`);
@@ -229,9 +290,9 @@ class SubProcess extends EventEmitter {
229
290
  // the proc
230
291
  this.handleLastLines();
231
292
  return await new B((resolve, reject) => {
232
- this.proc.on('close', resolve);
293
+ this.proc?.on('close', resolve);
233
294
  this.expectingExit = true;
234
- this.proc.kill(signal);
295
+ this.proc?.kill(signal);
235
296
  // this timeout needs unref() or node will wait for the timeout to fire before
236
297
  // exiting the process.
237
298
  setTimeout(() => {
@@ -246,8 +307,8 @@ class SubProcess extends EventEmitter {
246
307
  }
247
308
 
248
309
  return await new B((resolve, reject) => {
249
- this.proc.on('exit', (code) => {
250
- if (allowedExitCodes.indexOf(code) === -1) {
310
+ this.proc?.on('exit', (code) => {
311
+ if (code !== null && allowedExitCodes.indexOf(code) === -1) {
251
312
  reject(new Error(`Process ended with exitcode ${code} (cmd: '${this.rep}')`));
252
313
  } else {
253
314
  resolve(code);
@@ -276,3 +337,10 @@ class SubProcess extends EventEmitter {
276
337
 
277
338
  export { SubProcess };
278
339
  export default SubProcess;
340
+
341
+ /**
342
+ * @callback StartDetector
343
+ * @param {string} stdout
344
+ * @param {string} [stderr]
345
+ * @returns {any}
346
+ */
package/package.json CHANGED
@@ -1,24 +1,25 @@
1
1
  {
2
2
  "name": "teen_process",
3
+ "version": "2.0.1",
3
4
  "description": "A grown up version of Node's spawn/exec",
4
5
  "keywords": [
5
6
  "child_process",
6
- "process management"
7
+ "process management",
8
+ "subprocess",
9
+ "spawn",
10
+ "exec",
11
+ "process",
12
+ "child"
7
13
  ],
8
- "version": "2.0.0",
9
- "author": "appium",
10
- "license": "Apache-2.0",
11
- "repository": {
12
- "type": "git",
13
- "url": "https://github.com/appium/node-teen_process.git"
14
- },
15
14
  "bugs": {
16
15
  "url": "https://github.com/appium/node-teen_process/issues"
17
16
  },
18
- "engines": {
19
- "node": ">=14",
20
- "npm": ">=6"
17
+ "repository": {
18
+ "type": "git",
19
+ "url": "https://github.com/appium/node-teen_process.git"
21
20
  },
21
+ "license": "Apache-2.0",
22
+ "author": "Appium Contributors",
22
23
  "main": "./index.js",
23
24
  "bin": {},
24
25
  "directories": {
@@ -29,40 +30,72 @@
29
30
  "lib",
30
31
  "build/lib"
31
32
  ],
32
- "dependencies": {
33
- "@babel/runtime": "^7.0.0",
34
- "bluebird": "^3.5.1",
35
- "lodash": "^4.17.4",
36
- "shell-quote": "^1.4.3",
37
- "source-map-support": "^0.5.3",
38
- "which": "^2.0.2"
39
- },
40
33
  "scripts": {
41
- "clean": "rm -rf node_modules && rm -f package-lock.json && npm install",
42
- "build": "gulp transpile",
43
- "prepare": "gulp prepublish",
44
- "test": "gulp once",
45
- "watch": "gulp",
46
- "lint": "gulp eslint",
47
- "lint:fix": "gulp eslint --fix",
34
+ "build": "babel --out-dir=build/lib lib",
35
+ "dev": "npm run build -- --watch",
36
+ "lint": "eslint .",
37
+ "lint:fix": "npm run lint -- --fix",
38
+ "lint:types": "tsc",
39
+ "precommit-lint": "lint-staged",
48
40
  "precommit-msg": "echo 'Pre-commit checks...' && exit 0",
49
- "precommit-test": "REPORTER=dot gulp once"
41
+ "prepare": "npm run build",
42
+ "test": "mocha"
50
43
  },
51
44
  "pre-commit": [
52
45
  "precommit-msg",
53
- "precommit-test"
46
+ "precommit-lint"
54
47
  ],
48
+ "lint-staged": {
49
+ "*.js": [
50
+ "eslint --fix"
51
+ ]
52
+ },
53
+ "prettier": {
54
+ "bracketSpacing": false,
55
+ "printWidth": 100,
56
+ "singleQuote": true
57
+ },
58
+ "dependencies": {
59
+ "@babel/runtime": "7.18.9",
60
+ "bluebird": "3.7.2",
61
+ "lodash": "4.17.21",
62
+ "shell-quote": "1.7.3",
63
+ "source-map-support": "0.5.21",
64
+ "which": "2.0.2"
65
+ },
55
66
  "devDependencies": {
56
- "@appium/eslint-config-appium": "^6.0.2",
57
- "@appium/gulp-plugins": "^7.0.2",
58
- "@appium/support": "^2.59.2",
59
- "@types/bluebird": "^3.5.36",
60
- "@types/lodash": "^4.14.177",
61
- "@types/node": "^17.0.0",
62
- "@types/shell-quote": "^1.7.1",
63
- "chai": "^4.1.2",
64
- "chai-as-promised": "^7.1.1",
65
- "gulp": "^4.0.0",
66
- "pre-commit": "^1.2.2"
67
+ "@appium/eslint-config-appium": "6.0.4",
68
+ "@appium/support": "2.59.5",
69
+ "@babel/cli": "7.18.10",
70
+ "@babel/core": "7.18.10",
71
+ "@babel/eslint-parser": "7.18.9",
72
+ "@babel/plugin-transform-runtime": "7.18.10",
73
+ "@babel/preset-env": "7.18.10",
74
+ "@babel/register": "7.18.9",
75
+ "@types/bluebird": "3.5.36",
76
+ "@types/chai": "4.3.3",
77
+ "@types/chai-as-promised": "7.1.5",
78
+ "@types/lodash": "4.14.182",
79
+ "@types/mocha": "9.1.1",
80
+ "@types/node": "18.6.5",
81
+ "@types/shell-quote": "1.7.1",
82
+ "@types/which": "2.0.1",
83
+ "babel-plugin-source-map-support": "2.2.0",
84
+ "chai": "4.3.6",
85
+ "chai-as-promised": "7.1.1",
86
+ "eslint": "7.32.0",
87
+ "eslint-config-prettier": "8.5.0",
88
+ "eslint-plugin-import": "2.26.0",
89
+ "eslint-plugin-mocha": "9.0.0",
90
+ "eslint-plugin-promise": "6.0.0",
91
+ "lint-staged": "13.0.3",
92
+ "mocha": "10.0.0",
93
+ "pre-commit": "1.2.2",
94
+ "prettier": "2.7.1",
95
+ "typescript": "4.7.4"
96
+ },
97
+ "engines": {
98
+ "node": ">=14",
99
+ "npm": ">=6"
67
100
  }
68
101
  }