cli-mocker
v1.0.4
Published
Quickly mock CLI commands for testing purposes
Downloads
106
Readme
CLI Mocker
This mini utility is used to help mock your CLI tools when writing tests in frameworks like Mocha or Jest. It will spawn your CLI tool, and synchronously execute an array of predefined commands you provide like arrow/enter keys, text inputs, etc.
Install
yarn add cli-mocker --dev
ornpm install cli-mocker --save-dev
Usage
import { run } from 'cli-mocker';
const { output, lastOutput } = await run('npx my-cli-command', [/* COMMANDS */]);
Available Inputs and Commands
Commands run synchronously, so the order of the commands that you use matters. Currently, this library supports the following inputs:
Up arrow key
import { UP } from 'cli-mocker';
Down arrow key
import { DOWN } from 'cli-mocker';
Enter key
import { ENTER } from 'cli-mocker';
Shut down CLI
import { EXIT } from 'cli-mocker';
String inputs
You can pass any string argument to your cli. For example, filling in an input prompt with "hello, world!".
Example with Mocha
import chai from 'chai';
import {
run,
UP,
DOWN,
ENTER,
EXIT
} from 'cli-mocker';
const { expect } = chai;
describe('Test CLI', function() {
it('Runs', async () => {
const { output, lastOutput } = await run('npx my-cli-command', [
// Press down arrow key
DOWN,
// Press enter
ENTER,
// Press up arrow key
UP,
// Type something
'Hello, world!',
ENTER,
// Shut down CLI tool
EXIT
]);
return expect(lastOutput).to.equal(`Some value from your CLI tool's console.log() output`);
});
})
Contributing
Pull requests and feature requests are welcomed!
Husky is set up to run linting and formatting before commits.