Skip to content

Commit

Permalink
test: use assert.throw to test exceptions
Browse files Browse the repository at this point in the history
The test wasn't checking directly that an assertion was thrown. Instead,
it was checking that spawn did not sucessfully spawn a non-existent
command.

However, the command chosen, dir, exists in GNU coreutils, so it exists
on Linux (though not on BSD derived OS X). The test as written passed on
Linux, even with the TypeError it is supposed to be checking for deleted
from spawn(). It would also pass on Windows if a ls.exe existed.

The approach is unnecessarily obscure, assert.throw() is for asserting
code throws, using it is more clear and works regardless of what
commands do or do not exist.

PR-URL: nodejs/node-v0.x-archive#8454
Reviewed-by: Trevor Norris <[email protected]>

Cherry-picked-from: nodejs/node-v0.x-archive@2ff29cc

Conflicts:
	test/parallel/test-child-process-spawn-typeerror.js
  • Loading branch information
sam-github authored and piscisaureus committed Jan 13, 2015
1 parent 22d2058 commit f767226
Showing 1 changed file with 11 additions and 23 deletions.
34 changes: 11 additions & 23 deletions test/parallel/test-child-process-spawn-typeerror.js
Original file line number Diff line number Diff line change
@@ -1,23 +1,14 @@
var spawn = require('child_process').spawn,
assert = require('assert'),
windows = (process.platform === 'win32'),
cmd = (windows) ? 'rundll32' : 'ls',
invalidcmd = 'hopefully_you_dont_have_this_on_your_machine',
invalidArgsMsg = /Incorrect value of args option/,
invalidOptionsMsg = /options argument must be an object/,
errors = 0;

try {
// Ensure this throws a TypeError
var child = spawn(invalidcmd, 'this is not an array');

child.on('error', function (err) {
errors++;
});

} catch (e) {
assert.equal(e instanceof TypeError, true);
}
var assert = require('assert');
var child_process = require('child_process');
var spawn = child_process.spawn;
var cmd = (process.platform === 'win32') ? 'rundll32' : 'ls';
var invalidArgsMsg = /Incorrect value of args option/;
var invalidOptionsMsg = /options argument must be an object/;

// verify that args argument must be an array
assert.throws(function() {
spawn(cmd, 'this is not an array');
}, TypeError);

// verify that valid argument combinations do not throw
assert.doesNotThrow(function() {
Expand Down Expand Up @@ -57,6 +48,3 @@ assert.throws(function() {
spawn(cmd, [], 1);
}, invalidOptionsMsg);

process.on('exit', function() {
assert.equal(errors, 0);
});

0 comments on commit f767226

Please sign in to comment.