Skip to content

Commit

Permalink
Merge pull request #4 from zendesk/dderidder/X-mochajs-pr-review-part2
Browse files Browse the repository at this point in the history
Fix exit code when no signal caught
  • Loading branch information
73rhodes authored Apr 11, 2024
2 parents ad30057 + 34f2822 commit 3438da6
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 3 deletions.
2 changes: 1 addition & 1 deletion bin/mocha.js
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,7 @@ if (mochaArgs['node-option'] || Object.keys(nodeArgs).length || hasInspect) {
process.kill(process.pid, signal);
}
} else {
process.exit(code);
process.exit((mochaArgs['posix-exit-codes'] === true) ? 0 : code);
}
});
});
Expand Down
27 changes: 25 additions & 2 deletions test/integration/options/posixExitCodes.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ var helpers = require('../helpers');
var runMocha = helpers.runMocha;

describe('--posix-exit-codes', function () {
describe('when enabled with node options', function () {
describe('when enabled, and with node options', function () {
var args = ['--no-warnings', '--posix-exit-codes'];

it('should exit with code 134 on SIGABRT', function (done) {
Expand All @@ -28,9 +28,20 @@ describe('--posix-exit-codes', function () {
done();
});
});

it('should exit with code 0 even if there are test failures', function (done) {
var fixture = 'failing.fixture.js';
runMocha(fixture, args, function postmortem(err, res) {
if (err) {
return done(err);
}
expect(res.code, 'to be', 0);
done();
});
});
});

describe('when not enabled with node options', function () {
describe('when not enabled, and with node options', function () {
it('should exit with code null on SIGABRT', function (done) {
var fixture = 'signals-sigabrt.fixture.js';
var args = ['--no-warnings'];
Expand All @@ -42,5 +53,17 @@ describe('--posix-exit-codes', function () {
done();
});
});

it('should exit with the number of failed tests', function (done) {
var fixture = 'failing.fixture.js'; // one failing test
var args = ['--no-warnings'];
runMocha(fixture, args, function postmortem(err, res) {
if (err) {
return done(err);
}
expect(res.code, 'to be', 1);
done();
});
});
});
});

0 comments on commit 3438da6

Please sign in to comment.