diff --git a/package.json b/package.json index be3ad3be7..0adee4440 100644 --- a/package.json +++ b/package.json @@ -90,6 +90,7 @@ "devDependencies": { "coveralls": "^2.11.4", "nyc": "^3.2.2", + "signal-exit": "^2.1.2", "tap-dot": "^1.0.0", "tape": "^4.0.0", "xo": "*" diff --git a/test/fixture/long-running.js b/test/fixture/long-running.js index 5b964c5a0..9dae43a3a 100644 --- a/test/fixture/long-running.js +++ b/test/fixture/long-running.js @@ -1,12 +1,25 @@ 'use strict'; const test = require('../../'); +var onExit = require('signal-exit'); test('long running', function (t) { t.plan(1); + onExit(function () { + // simulate an exit hook that lasts a short while + var start = Date.now(); + while(Date.now() - start < 2000) { + //synchronously wait for 2 seconds + } + process.send({name:'cleanup-completed', data: {completed: true}}); + }, {alwaysLast: true}); + + setTimeout(function () { + t.ok(true); + }); + setTimeout(function () { + // this would keep the process running for a long time. console.log('I\'m gonna live forever!!'); }, 15000); - - t.ok(true); }); diff --git a/test/fork.js b/test/fork.js index 11c9bb382..a8922735c 100644 --- a/test/fork.js +++ b/test/fork.js @@ -41,12 +41,17 @@ test('rejects on error and streams output', function (t) { }); test('exit after tests are finished', function (t) { - t.plan(1); + t.plan(2); var start = Date.now(); + var cleanupCompleted = false; fork(fixture('long-running.js')) .on('exit', function () { - t.ok(Date.now() - start < 10000); + t.ok(Date.now() - start < 10000, 'did NOT wait for setTimeout(fn, 15000'); + t.ok(cleanupCompleted, 'did wait for onExit(fn) to complete'); + }) + .on('cleanup-completed', function (event) { + cleanupCompleted = event.completed; }); });