Skip to content

Latest commit

 

History

History
132 lines (88 loc) · 3.39 KB

README.md

File metadata and controls

132 lines (88 loc) · 3.39 KB

High-level, interactive, child process runner for Node.JS

Circle CI Dependency Status devDependency Status

High-level support for running, observing, and interacting with child processes in Node.js

ObservableProcess = require('observable-process')
process = new ObservableProcess('my-server --port 3000')

You can also provide the process to run as an argv array:

process = new ObservableProcess(['my-server', '--port', '3000'])

Set the working directory of the subshell

process = new ObservableProcess('my-server', { cwd: '~/tmp' })

Set environment variables in the subshell

process = new ObservableProcess('my-server', { env: { foo: 'bar' } })

Waiting for output

You can be notified when the process prints given text on stdout or stderr:

process.wait('listening on port 3000', function() {
  // this method runs after the process prints "listening on port 3000"
});

This is useful for waiting until slow-starting services are fully booted up.

Get console output

You can retrieve the output to the various IO streams:

process.fullOutput()  // returns all the output produced by the subprocess so far

Configure how console output is printed

By default the output of the observed process is printed on the console. To disable logging:

process = new ObservableProcess('my-server', { stdout: false, stderr: false })

You can also customize logging by providing custom stdout and stderr objects (which needs to have the method write):

myStdOut = {
  write: (text) => { ... }
}
myStdErr = {
  write: (text) => { ... }
}
process = new ObservableProcess('my-server', { stdout: myStdOut, stderr: myStdErr })

You can use dim-console to print output from the subshell dimmed, so that it is easy to distinguish from output of the main thread.

dimConsole = require('dim-console')
process = new ObservableProcess('my-server', { stdout: dimConsole.stdout, stderr: dimConsole.stderr })

To get more detailed output like lifecycle events of the subshell (printed to the error stream):

process = new ObservableProcess('my-server', { verbose: true })

Kill the process

If the process is running, you can kill it via:

process.kill()

This sets the killed property on the ObservableProcess instance, so that manual kills can be distinguished from crashes.

To let ObservableProcess notify you when a process ended, subscribe to the ended event:

process.on 'ended', (exitCode, killed) => {
  // the process has ended here
  // you can also access the exit code via process.exitCode
}

Get the process id

process.pid()

related libraries

  • nexpect: Allows to define expectations on command output, and send it input, but doesn't allow to add more listeners to existing long-running processes, which makes declarative testing hard.