Skip to content

Commit

Permalink
Merge pull request #7848 from appium/dan-arg-parse-fix
Browse files Browse the repository at this point in the history
Don't allow undefined process.argv[1] in parser
  • Loading branch information
jlipps committed Feb 10, 2017
2 parents 56ebf37 + 6f5a9d1 commit b57d1a3
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 1 deletion.
3 changes: 2 additions & 1 deletion lib/parser.js
Expand Up @@ -782,7 +782,8 @@ function getParser () {
let parser = new ArgumentParser({
version: pkgObj.version,
addHelp: true,
description: 'A webdriver-compatible server for use with native and hybrid iOS and Android applications.'
description: 'A webdriver-compatible server for use with native and hybrid iOS and Android applications.',
prog: process.argv[1] || 'Appium'
});
let allArgs = _.union(args, deprecatedArgs);
parser.rawArgs = allArgs;
Expand Down
24 changes: 24 additions & 0 deletions test/config-specs.js
Expand Up @@ -194,6 +194,30 @@ describe('Config', () => {
});
});

describe('parsing args with empty argv[1]', () => {
let argv1;

before(() => {
argv1 = process.argv[1];
});

after(() => {
process.argv[1] = argv1;
});

it('should not fail if process.argv[1] is undefined', () => {
process.argv[1] = undefined;
let args = getParser();
args.prog.should.be.equal('Appium');
});

it('should set "prog" to process.argv[1]', () => {
process.argv[1] = 'Hello World';
let args = getParser();
args.prog.should.be.equal('Hello World');
});
});

describe('validateServerArgs', () => {
let parser = getParser();
parser.debug = true; // throw instead of exit on error; pass as option instead?
Expand Down

0 comments on commit b57d1a3

Please sign in to comment.