Skip to content

Latest commit

 

History

History
137 lines (93 loc) · 4.36 KB

execution.md

File metadata and controls

137 lines (93 loc) · 4.36 KB
execa logo

▶️ Basic execution

Array syntax

import {execa} from 'execa';

await execa('npm', ['run', 'build']);

Template string syntax

All available methods can use either the array syntax or the template string syntax, which are equivalent.

await execa`npm run build`;

String argument

await execa`npm run ${'task with space'}`;

Number argument

await execa`npm run build --concurrency ${2}`;

Subcommands

const result = await execa`get-concurrency`;

// Uses `result.stdout`
await execa`npm run build --concurrency ${result}`;

Concatenation

const tmpDirectory = '/tmp';
await execa`mkdir ${tmpDirectory}/filename`;

Multiple arguments

const result = await execa`get-concurrency`;

await execa`npm ${['run', 'build', '--concurrency', 2]}`;

Multiple lines

await execa`npm run build
	--concurrency 2
	--fail-fast`;

Options

Options can be passed to influence the execution's behavior.

Array syntax

await execa('npm', ['run', 'build'], {timeout: 5000});

Template string syntax

await execa({timeout: 5000})`npm run build`;

Global/shared options

const timedExeca = execa({timeout: 5000});

await timedExeca('npm', ['run', 'build']);
await timedExeca`npm run test`;

Return value

Subprocess

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);

Result

The subprocess is also a Promise that resolves with the result.

const {stdout} = await execa`npm run build`;

Synchronous execution

Every method can be called synchronously by appending Sync to the method's name. The result is returned 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:


Next: 💬 Escaping/quoting
Top: Table of contents