spawn-mocha-parallel

Spawn mocha child processes in parallel.

Usage no npm install needed!

<script type="module">
  import spawnMochaParallel from 'https://cdn.skypack.dev/spawn-mocha-parallel';
</script>

README

spawn-mocha-parallel

This let you run your test in parallel by spawning several child processes. It was designed to be used with gulp, but since it relies only on npm, it may be used within various configuration.

NPM version Downloads Dependency Status devDependency Status

Credits

This was originaly a fork of [gulp-spawn-mocha] but has deviated a lot since then.

Usage

Using built in mochaStream:

var mochaStream = require('spawn-mocha-parallel').mochaStream;

var mocha = mochaStream({concurrency: 10});

gulp.task('test-mocha', function() {
  gulp.src('**/*-specs.js', {read: false}) 
    .pipe(mocha)
    .on('error', console.error)
});

Using SpawnMocha

var SpawnMocha = require('spawn-mocha-parallel').SpawnMocha,
    _ = require('lodash');
    through = require('through');

// customize output as you need
function mochaStream(opts) {
  opts = opts || {};
  var spawnMocha = new SpawnMocha(opts);
  var stream = through(function write(file) {
    spawnMocha.add(file.path);
  }, function() {});
  var errors = [];
  spawnMocha.on('error', function(err) {
    console.error(err.toString());
    errors.push(err);
  }).on('end', function() {
    if(errors.length > 0) {
      console.error('ERROR SUMMARY: ');
      _(errors).each(function(err) {
        console.error(err);
        console.error(err.stack);
      });
      stream.emit('error', "Some tests failed.");
    }
    stream.emit('end');
  });
  return stream;
}

var mocha = mochaStream({concurrency: 3});

gulp.task('test-custom-mocha', function() {
  gulp.src('**/*-specs.js', {read: false}) 
    .pipe(mocha)
    .on('error', console.error)
});

Options

  • concurrency: # of mocha instance running in parallel (default: 1)
  • env mocha running env, (default: process.env)
  • flags: mocha flags (default: none)
  • liveOutput: print output direct to console
  • errorSummary: show error summary (default: true)

Todo

  • concatenate mocha status at the end

License

MIT