import {execa} from 'execa';
await execa('npm', ['run', 'build']);All available methods can use either the array syntax or the template string syntax, which are equivalent.
await execa`npm run build`;await execa`npm run ${'task with space'}`;await execa`npm run build --concurrency ${2}`;const result = await execa`get-concurrency`;
// Uses `result.stdout`
await execa`npm run build --concurrency ${result}`;const tmpDirectory = '/tmp';
await execa`mkdir ${tmpDirectory}/filename`;const result = await execa`get-concurrency`;
await execa`npm ${['run', 'build', '--concurrency', result]}`;await execa`npm run build ${[]}`;
// Same as:
await execa('npm', ['run', 'build']);await execa`npm run build ${''}`;
// Same as:
await execa('npm', ['run', 'build', '']);const commandArguments = failFast ? ['--fail-fast'] : [];
await execa`npm run build ${commandArguments}`;await execa`npm run build
--concurrency 2
--fail-fast`;By default, any shell-specific syntax has no special meaning and does not need to be escaped. This prevents shell injections. More info.
// This prints `$TASK_NAME`, not `build`
await execa({env: {TASK_NAME: 'build'}})`echo $TASK_NAME`;Options can be passed to influence the execution's behavior.
await execa('npm', ['run', 'build'], {timeout: 5000});await execa({timeout: 5000})`npm run build`;const timedExeca = execa({timeout: 5000});
await timedExeca('npm', ['run', 'build']);
await timedExeca`npm run test`;The subprocess is returned as soon as it is spawned. It is a child_process instance with additional methods and properties.
const subprocess = execa`npm run build`;
console.log(subprocess.pid);The subprocess is also a Promise that resolves with the result.
const {stdout} = await execa`npm run build`;execaSync() and $.sync() return the result without needing to await. The subprocess is not returned: its methods and properties are not available.
import {execaSync} from 'execa';
const {stdout} = execaSync`npm run build`;Synchronous execution is generally discouraged as it holds the CPU and prevents parallelization. Also, the following features cannot be used:
- Streams:
subprocess.stdin,subprocess.stdout,subprocess.stderr,subprocess.readable(),subprocess.writable(),subprocess.duplex(). - The
stdin,stdout,stderrandstdiooptions cannot be'overlapped', an async iterable, an async transform, aDuplex, nor a web stream. Node.js streams can be passed but only if either they have a file descriptor, or theinputoption is used. - Signal termination:
subprocess.kill(),subprocess.pid,cleanupoption,cancelSignaloption,forceKillAfterDelayoption. - Piping multiple subprocesses:
subprocess.pipe(). subprocess.iterable().- IPC:
sendMessage(),getOneMessage(),getEachMessage(),result.ipcOutput,ipcoption,serializationoption,ipcInputoption. result.allis not interleaved.detachedoption.- The
maxBufferoption is always measured in bytes, not in characters, lines nor objects. Also, it ignores transforms and theencodingoption.