Skip to content

Commit

Permalink
feat: feed args to exec when detecting script (#1273)
Browse files Browse the repository at this point in the history
Fixes #1263

The way it works:

- If the script is detected via index.js from the directory, or from the
package, then all the arguments on the CLI are shifted to execArgs

- If there was a double-dash on the CLI args, then only those before the
double-dash are given to execArgs and the rest remain passed to the
script
  • Loading branch information
remy authored Feb 27, 2018
1 parent f4391d4 commit e41f3c3
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 7 deletions.
7 changes: 7 additions & 0 deletions lib/config/load.js
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,13 @@ function load(settings, options, config, callback) {
if (!options.script && !options.exec) {
var found = findAppScript();
if (found) {
// if the script is found as a result of not being on the command
// line, then we move any of the pre double-dash args in execArgs
const n = options.scriptPosition || options.args.length;
options.execArgs = (options.execArgs || [])
.concat(options.args.splice(0, n));
options.scriptPosition = null;

options.script = found;
}
}
Expand Down
15 changes: 8 additions & 7 deletions test/cli/exec.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -68,14 +68,14 @@ describe('nodemon exec', function () {
});

it('should support --debug', function () {
var options = exec({ script: 'app.js', nodeArgs: [ '--debug' ]});
var options = exec({ script: 'app.js', nodeArgs: ['--debug'] });
var cmd = toCmd(options);
assert(cmd.string === 'node --debug app.js', cmd.string);
assert(options.ext.indexOf('js') !== -1, 'extension watched is .js');
});

it('should support --debug=XXXX', function () {
var options = exec({ script: 'app.js', nodeArgs: [ '--debug=9999' ]});
var options = exec({ script: 'app.js', nodeArgs: ['--debug=9999'] });
var cmd = toCmd(options);
assert(cmd.string === 'node --debug=9999 app.js', cmd.string);
assert(options.exec === 'node');
Expand Down Expand Up @@ -140,30 +140,30 @@ describe('nodemon exec', function () {
});

it('should support coffeescript in debug mode', function () {
var options = exec({ script: 'app.coffee', nodeArgs: [ '--debug' ] });
var options = exec({ script: 'app.coffee', nodeArgs: ['--debug'] });

assert(options.exec.indexOf('coffee') === 0, 'using coffeescript to execute');
assert(options.execArgs[1].indexOf('--debug') !== -1);
assert(options.ext.indexOf('coffee') !== -1);
});

it('should support custom execs', function () {
var options = exec({ script: 'app.py', exec: 'python'});
var options = exec({ script: 'app.py', exec: 'python' });

assert(options.exec === 'python');
assert(options.ext.indexOf('py') !== -1);
});

it('should support custom executables with arguments', function () {
var options = exec({ script: 'app.py', exec: 'python --debug'});
var options = exec({ script: 'app.py', exec: 'python --debug' });
var cmd = toCmd(options);

assert(cmd.string === 'python --debug app.py', cmd.string);
assert(options.ext.indexOf('py') !== -1);
});

it('should support an array of exec arguments', function() {
var options = exec({script: 'app.js', exec: ['/path to node', '-v']});
it('should support an array of exec arguments', function () {
var options = exec({ script: 'app.js', exec: ['/path to node', '-v'] });

assert(options.exec === '/path to node', options.exec);
assert(options.execArgs.length === 1, options.execArgs.length);
Expand Down Expand Up @@ -219,4 +219,5 @@ describe('nodemon exec', function () {
var cmd = toCmd(options);
assert(cmd.string === 'node index', cmd.string);
});

});

0 comments on commit e41f3c3

Please sign in to comment.