Soren is an minimal test runner designed to help E2E tests with interactive CLI tools such as an application using Inquirer. It's flaky and experimental, please submit any issues that you might encounter.
$ npm install -g soren
soren binPath="./my/repo/dot.js" -- optionalArgs
Example from a E2E test with the webpack-cli
'use strict';
const assert = require('assert');
/* global describe question */
// Webpack-cli -> soren binPath="YourPathToWebpackCLI" -- init
// Alternatively, clone webpack-cli and run 'Soren' inside the repo
describe('init', () => {
question('Will your application have multiple bundles? (Y/n)', 'n', (answer) => {
assert.equal(answer, 'n');
});
question('Which module will be the first to enter the application?', 'app.js', (answer) => {
assert.equal(answer, 'app.js');
});
question('Which folder will your generated bundles be in? [default: dist]:',
'./dist', (answer) => {
assert.equal(answer, './dist');
});
question('Are you going to use this in production? (Y/n)', 'Y', (answer) => {
assert.equal(answer, 'Y');
});
question('Will you be using ES2015? (Y/n)', 'Y', (answer) => {
assert.equal(answer, 'Y');
});
question(` Will you use one of the below CSS solutions?
1) SASS
2) LESS
3) CSS
4) PostCSS
5) No
Answer:`, 2, (answer) => {
assert.equal(answer, 2);
});
question(`If you want to bundle your CSS files, what will you name the bundle? (press en
ter to skip)`, 'enter', (answer) => {
assert.equal(answer, 'enter');
});
question('Name your \'webpack.[name].js?\' [default: \'prod\']:', 'dev', (answer) => {
assert.equal(answer, 'dev');
});
});
There's several things you may have noticed here. First of all, your interactive questions need to match exactly, as well as they have to be in order. Secondly, we're using the native assert
module for node, while we figure out how to implement this nicely with other test runners.
- Filename for each of the tests needs to be named
example.stdin.js
- When you're running
soren
,describe
should have the argument you pass it, as well as the filename:soren binPath=../some/path -- example
- Describe needs then to look like:
describe('example', () => {...})
- Run Soren in a Docker container
- If you are producing code, leave that checks for tools like Jest and run that command after Soren has run its command. (Example:
npm run E2E:soren && npm run E2E:jest
)
In the future, Soren should be consumed with a Docker container. This way, an E2E test that produces some output can be tested without consuming "Junk" code in your workspace.
- Less flaky assertions
- Opt in docker and usage after a CLI command has been finished