447 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
		
		
			
		
	
	
			447 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
|  | var optimist = require('../index'); | ||
|  | var path = require('path'); | ||
|  | var test = require('tap').test; | ||
|  | 
 | ||
|  | var $0 = 'node ./' + path.relative(process.cwd(), __filename); | ||
|  | 
 | ||
|  | test('short boolean', function (t) { | ||
|  |     var parse = optimist.parse([ '-b' ]); | ||
|  |     t.same(parse, { b : true, _ : [], $0 : $0 }); | ||
|  |     t.same(typeof parse.b, 'boolean'); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('long boolean', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '--bool' ]), | ||
|  |         { bool : true, _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  |      | ||
|  | test('bare', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ 'foo', 'bar', 'baz' ]), | ||
|  |         { _ : [ 'foo', 'bar', 'baz' ], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('short group', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '-cats' ]), | ||
|  |         { c : true, a : true, t : true, s : true, _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('short group next', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '-cats', 'meow' ]), | ||
|  |         { c : true, a : true, t : true, s : 'meow', _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  |   | ||
|  | test('short capture', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '-h', 'localhost' ]), | ||
|  |         { h : 'localhost', _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('short captures', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '-h', 'localhost', '-p', '555' ]), | ||
|  |         { h : 'localhost', p : 555, _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('long capture sp', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '--pow', 'xixxle' ]), | ||
|  |         { pow : 'xixxle', _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('long capture eq', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '--pow=xixxle' ]), | ||
|  |         { pow : 'xixxle', _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end() | ||
|  | }); | ||
|  | 
 | ||
|  | test('long captures sp', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '--host', 'localhost', '--port', '555' ]), | ||
|  |         { host : 'localhost', port : 555, _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('long captures eq', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '--host=localhost', '--port=555' ]), | ||
|  |         { host : 'localhost', port : 555, _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('mixed short bool and capture', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '-h', 'localhost', '-fp', '555', 'script.js' ]), | ||
|  |         { | ||
|  |             f : true, p : 555, h : 'localhost', | ||
|  |             _ : [ 'script.js' ], $0 : $0, | ||
|  |         } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  |   | ||
|  | test('short and long', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '-h', 'localhost', '-fp', '555', 'script.js' ]), | ||
|  |         { | ||
|  |             f : true, p : 555, h : 'localhost', | ||
|  |             _ : [ 'script.js' ], $0 : $0, | ||
|  |         } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('no', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '--no-moo' ]), | ||
|  |         { moo : false, _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  |   | ||
|  | test('multi', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '-v', 'a', '-v', 'b', '-v', 'c' ]), | ||
|  |         { v : ['a','b','c'], _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  |   | ||
|  | test('comprehensive', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ | ||
|  |             '--name=meowmers', 'bare', '-cats', 'woo', | ||
|  |             '-h', 'awesome', '--multi=quux', | ||
|  |             '--key', 'value', | ||
|  |             '-b', '--bool', '--no-meep', '--multi=baz', | ||
|  |             '--', '--not-a-flag', 'eek' | ||
|  |         ]), | ||
|  |         { | ||
|  |             c : true, | ||
|  |             a : true, | ||
|  |             t : true, | ||
|  |             s : 'woo', | ||
|  |             h : 'awesome', | ||
|  |             b : true, | ||
|  |             bool : true, | ||
|  |             key : 'value', | ||
|  |             multi : [ 'quux', 'baz' ], | ||
|  |             meep : false, | ||
|  |             name : 'meowmers', | ||
|  |             _ : [ 'bare', '--not-a-flag', 'eek' ], | ||
|  |             $0 : $0 | ||
|  |         } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('nums', function (t) { | ||
|  |     var argv = optimist.parse([ | ||
|  |         '-x', '1234', | ||
|  |         '-y', '5.67', | ||
|  |         '-z', '1e7', | ||
|  |         '-w', '10f', | ||
|  |         '--hex', '0xdeadbeef', | ||
|  |         '789', | ||
|  |     ]); | ||
|  |     t.same(argv, { | ||
|  |         x : 1234, | ||
|  |         y : 5.67, | ||
|  |         z : 1e7, | ||
|  |         w : '10f', | ||
|  |         hex : 0xdeadbeef, | ||
|  |         _ : [ 789 ], | ||
|  |         $0 : $0 | ||
|  |     }); | ||
|  |     t.same(typeof argv.x, 'number'); | ||
|  |     t.same(typeof argv.y, 'number'); | ||
|  |     t.same(typeof argv.z, 'number'); | ||
|  |     t.same(typeof argv.w, 'string'); | ||
|  |     t.same(typeof argv.hex, 'number'); | ||
|  |     t.same(typeof argv._[0], 'number'); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('flag boolean', function (t) { | ||
|  |     var parse = optimist([ '-t', 'moo' ]).boolean(['t']).argv; | ||
|  |     t.same(parse, { t : true, _ : [ 'moo' ], $0 : $0 }); | ||
|  |     t.same(typeof parse.t, 'boolean'); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('flag boolean value', function (t) { | ||
|  |     var parse = optimist(['--verbose', 'false', 'moo', '-t', 'true']) | ||
|  |         .boolean(['t', 'verbose']).default('verbose', true).argv; | ||
|  |      | ||
|  |     t.same(parse, { | ||
|  |         verbose: false, | ||
|  |         t: true, | ||
|  |         _: ['moo'], | ||
|  |         $0 : $0 | ||
|  |     }); | ||
|  |      | ||
|  |     t.same(typeof parse.verbose, 'boolean'); | ||
|  |     t.same(typeof parse.t, 'boolean'); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('flag boolean default false', function (t) { | ||
|  |     var parse = optimist(['moo']) | ||
|  |         .boolean(['t', 'verbose']) | ||
|  |         .default('verbose', false) | ||
|  |         .default('t', false).argv; | ||
|  |      | ||
|  |     t.same(parse, { | ||
|  |         verbose: false, | ||
|  |         t: false, | ||
|  |         _: ['moo'], | ||
|  |         $0 : $0 | ||
|  |     }); | ||
|  |      | ||
|  |     t.same(typeof parse.verbose, 'boolean'); | ||
|  |     t.same(typeof parse.t, 'boolean'); | ||
|  |     t.end(); | ||
|  | 
 | ||
|  | }); | ||
|  | 
 | ||
|  | test('boolean groups', function (t) { | ||
|  |     var parse = optimist([ '-x', '-z', 'one', 'two', 'three' ]) | ||
|  |         .boolean(['x','y','z']).argv; | ||
|  |      | ||
|  |     t.same(parse, { | ||
|  |         x : true, | ||
|  |         y : false, | ||
|  |         z : true, | ||
|  |         _ : [ 'one', 'two', 'three' ], | ||
|  |         $0 : $0 | ||
|  |     }); | ||
|  |      | ||
|  |     t.same(typeof parse.x, 'boolean'); | ||
|  |     t.same(typeof parse.y, 'boolean'); | ||
|  |     t.same(typeof parse.z, 'boolean'); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('newlines in params' , function (t) { | ||
|  |     var args = optimist.parse([ '-s', "X\nX" ]) | ||
|  |     t.same(args, { _ : [], s : "X\nX", $0 : $0 }); | ||
|  | 
 | ||
|  |     // reproduce in bash:
 | ||
|  |     // VALUE="new
 | ||
|  |     // line"
 | ||
|  |     // node program.js --s="$VALUE"
 | ||
|  |     args = optimist.parse([ "--s=X\nX" ]) | ||
|  |     t.same(args, { _ : [], s : "X\nX", $0 : $0 }); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('strings' , function (t) { | ||
|  |     var s = optimist([ '-s', '0001234' ]).string('s').argv.s; | ||
|  |     t.same(s, '0001234'); | ||
|  |     t.same(typeof s, 'string'); | ||
|  |      | ||
|  |     var x = optimist([ '-x', '56' ]).string('x').argv.x; | ||
|  |     t.same(x, '56'); | ||
|  |     t.same(typeof x, 'string'); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('stringArgs', function (t) { | ||
|  |     var s = optimist([ '  ', '  ' ]).string('_').argv._; | ||
|  |     t.same(s.length, 2); | ||
|  |     t.same(typeof s[0], 'string'); | ||
|  |     t.same(s[0], '  '); | ||
|  |     t.same(typeof s[1], 'string'); | ||
|  |     t.same(s[1], '  '); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('slashBreak', function (t) { | ||
|  |     t.same( | ||
|  |         optimist.parse([ '-I/foo/bar/baz' ]), | ||
|  |         { I : '/foo/bar/baz', _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.same( | ||
|  |         optimist.parse([ '-xyz/foo/bar/baz' ]), | ||
|  |         { x : true, y : true, z : '/foo/bar/baz', _ : [], $0 : $0 } | ||
|  |     ); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('alias', function (t) { | ||
|  |     var argv = optimist([ '-f', '11', '--zoom', '55' ]) | ||
|  |         .alias('z', 'zoom') | ||
|  |         .argv | ||
|  |     ; | ||
|  |     t.equal(argv.zoom, 55); | ||
|  |     t.equal(argv.z, argv.zoom); | ||
|  |     t.equal(argv.f, 11); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('multiAlias', function (t) { | ||
|  |     var argv = optimist([ '-f', '11', '--zoom', '55' ]) | ||
|  |         .alias('z', [ 'zm', 'zoom' ]) | ||
|  |         .argv | ||
|  |     ; | ||
|  |     t.equal(argv.zoom, 55); | ||
|  |     t.equal(argv.z, argv.zoom); | ||
|  |     t.equal(argv.z, argv.zm); | ||
|  |     t.equal(argv.f, 11); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('boolean default true', function (t) { | ||
|  |     var argv = optimist.options({ | ||
|  |         sometrue: { | ||
|  |             boolean: true, | ||
|  |             default: true | ||
|  |         } | ||
|  |     }).argv; | ||
|  |    | ||
|  |     t.equal(argv.sometrue, true); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('boolean default false', function (t) { | ||
|  |     var argv = optimist.options({ | ||
|  |         somefalse: { | ||
|  |             boolean: true, | ||
|  |             default: false | ||
|  |         } | ||
|  |     }).argv; | ||
|  | 
 | ||
|  |     t.equal(argv.somefalse, false); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('nested dotted objects', function (t) { | ||
|  |     var argv = optimist([ | ||
|  |         '--foo.bar', '3', '--foo.baz', '4', | ||
|  |         '--foo.quux.quibble', '5', '--foo.quux.o_O', | ||
|  |         '--beep.boop' | ||
|  |     ]).argv; | ||
|  |      | ||
|  |     t.same(argv.foo, { | ||
|  |         bar : 3, | ||
|  |         baz : 4, | ||
|  |         quux : { | ||
|  |             quibble : 5, | ||
|  |             o_O : true | ||
|  |         }, | ||
|  |     }); | ||
|  |     t.same(argv.beep, { boop : true }); | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('boolean and alias with chainable api', function (t) { | ||
|  |     var aliased = [ '-h', 'derp' ]; | ||
|  |     var regular = [ '--herp',  'derp' ]; | ||
|  |     var opts = { | ||
|  |         herp: { alias: 'h', boolean: true } | ||
|  |     }; | ||
|  |     var aliasedArgv = optimist(aliased) | ||
|  |         .boolean('herp') | ||
|  |         .alias('h', 'herp') | ||
|  |         .argv; | ||
|  |     var propertyArgv = optimist(regular) | ||
|  |         .boolean('herp') | ||
|  |         .alias('h', 'herp') | ||
|  |         .argv; | ||
|  |     var expected = { | ||
|  |         herp: true, | ||
|  |         h: true, | ||
|  |         '_': [ 'derp' ], | ||
|  |         '$0': $0, | ||
|  |     }; | ||
|  | 
 | ||
|  |     t.same(aliasedArgv, expected); | ||
|  |     t.same(propertyArgv, expected);  | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('boolean and alias with options hash', function (t) { | ||
|  |     var aliased = [ '-h', 'derp' ]; | ||
|  |     var regular = [ '--herp', 'derp' ]; | ||
|  |     var opts = { | ||
|  |         herp: { alias: 'h', boolean: true } | ||
|  |     }; | ||
|  |     var aliasedArgv = optimist(aliased) | ||
|  |       .options(opts) | ||
|  |       .argv; | ||
|  |     var propertyArgv = optimist(regular).options(opts).argv; | ||
|  |     var expected = { | ||
|  |         herp: true, | ||
|  |         h: true, | ||
|  |         '_': [ 'derp' ], | ||
|  |         '$0': $0, | ||
|  |     }; | ||
|  | 
 | ||
|  |     t.same(aliasedArgv, expected); | ||
|  |     t.same(propertyArgv, expected); | ||
|  | 
 | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | test('boolean and alias using explicit true', function (t) { | ||
|  |     var aliased = [ '-h', 'true' ]; | ||
|  |     var regular = [ '--herp',  'true' ]; | ||
|  |     var opts = { | ||
|  |         herp: { alias: 'h', boolean: true } | ||
|  |     }; | ||
|  |     var aliasedArgv = optimist(aliased) | ||
|  |         .boolean('h') | ||
|  |         .alias('h', 'herp') | ||
|  |         .argv; | ||
|  |     var propertyArgv = optimist(regular) | ||
|  |         .boolean('h') | ||
|  |         .alias('h', 'herp') | ||
|  |         .argv; | ||
|  |     var expected = { | ||
|  |         herp: true, | ||
|  |         h: true, | ||
|  |         '_': [ ], | ||
|  |         '$0': $0, | ||
|  |     }; | ||
|  | 
 | ||
|  |     t.same(aliasedArgv, expected); | ||
|  |     t.same(propertyArgv, expected);  | ||
|  |     t.end(); | ||
|  | }); | ||
|  | 
 | ||
|  | // regression, see https://github.com/substack/node-optimist/issues/71
 | ||
|  | test('boolean and --x=true', function(t) { | ||
|  |     var parsed = optimist(['--boool', '--other=true']).boolean('boool').argv; | ||
|  | 
 | ||
|  |     t.same(parsed.boool, true); | ||
|  |     t.same(parsed.other, 'true'); | ||
|  | 
 | ||
|  |     parsed = optimist(['--boool', '--other=false']).boolean('boool').argv; | ||
|  | 
 | ||
|  |     t.same(parsed.boool, true); | ||
|  |     t.same(parsed.other, 'false'); | ||
|  |     t.end(); | ||
|  | }); |