194 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			V
		
	
	
			
		
		
	
	
			194 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			V
		
	
	
 | 
						|
import flag
 | 
						|
 | 
						|
fn test_if_flag_not_given_return_default_values() {
 | 
						|
  mut fp := flag.new_flag_parser([]string)
 | 
						|
  
 | 
						|
  assert false == fp.bool('a_bool', false, '')
 | 
						|
    && 42 == fp.int('an_int', 42, '')
 | 
						|
    && 1.0 == fp.float('a_float', 1.0, '')
 | 
						|
    && 'stuff' == fp.string('a_string', 'stuff', '')
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
fn test_could_define_application_name_and_version() {
 | 
						|
  mut fp := flag.new_flag_parser([]string)
 | 
						|
  fp.application('test app')
 | 
						|
  fp.version('0.0.42')
 | 
						|
  fp.description('some text')
 | 
						|
 | 
						|
  assert fp.application_name == 'test app'
 | 
						|
    && fp.application_version == '0.0.42'
 | 
						|
    && fp.application_description == 'some text'
 | 
						|
}
 | 
						|
 | 
						|
fn test_bool_flags_do_not_need_an_value() {
 | 
						|
  mut fp := flag.new_flag_parser(['--a_bool'])
 | 
						|
 | 
						|
  assert true == fp.bool('a_bool', false, '')
 | 
						|
}
 | 
						|
 | 
						|
fn test_flags_could_be_defined_with_eq() {
 | 
						|
  mut fp := flag.new_flag_parser([
 | 
						|
    '--an_int=42', 
 | 
						|
    '--a_float=2.0',
 | 
						|
    '--bool_without',
 | 
						|
    '--a_string=stuff',
 | 
						|
    '--a_bool=true'])
 | 
						|
  
 | 
						|
  assert 42 == fp.int('an_int', 666, '')
 | 
						|
    && true == fp.bool('a_bool', false, '')
 | 
						|
    && true == fp.bool('bool_without', false, '')
 | 
						|
    && 2.0 == fp.float('a_float', 1.0, '')
 | 
						|
    && 'stuff' == fp.string('a_string', 'not_stuff', '')
 | 
						|
}
 | 
						|
 | 
						|
fn test_values_could_be_defined_without_eq() {
 | 
						|
  mut fp := flag.new_flag_parser([
 | 
						|
    '--an_int', '42', 
 | 
						|
    '--a_float', '2.0',
 | 
						|
    '--bool_without',
 | 
						|
    '--a_string', 'stuff',
 | 
						|
    '--a_bool', 'true'])
 | 
						|
  
 | 
						|
  assert 42 == fp.int('an_int', 666, '')
 | 
						|
    && true == fp.bool('a_bool', false, '')
 | 
						|
    && true == fp.bool('bool_without', false, '')
 | 
						|
    && 2.0 == fp.float('a_float', 1.0, '')
 | 
						|
    && 'stuff' == fp.string('a_string', 'not_stuff', '')
 | 
						|
}
 | 
						|
 | 
						|
fn test_values_could_be_defined_mixed() {
 | 
						|
  mut fp := flag.new_flag_parser([
 | 
						|
    '--an_int', '42', 
 | 
						|
    '--a_float=2.0',
 | 
						|
    '--bool_without',
 | 
						|
    '--a_string', 'stuff',
 | 
						|
    '--a_bool=true'])
 | 
						|
  
 | 
						|
  assert 42 == fp.int('an_int', 666, '')
 | 
						|
    && true == fp.bool('a_bool', false, '')
 | 
						|
    && true == fp.bool('bool_without', false, '')
 | 
						|
    && 2.0 == fp.float('a_float', 1.0, '')
 | 
						|
    && 'stuff' == fp.string('a_string', 'not_stuff', '')
 | 
						|
}
 | 
						|
 | 
						|
fn test_beaware_for_argument_names_with_same_prefix() {
 | 
						|
  mut fp := flag.new_flag_parser([
 | 
						|
    '--short', '5', 
 | 
						|
    '--shorter=7'
 | 
						|
    ])
 | 
						|
  
 | 
						|
  assert 5 == fp.int('short', 666, '')
 | 
						|
    && 7 == fp.int('shorter', 666, '')
 | 
						|
}
 | 
						|
 | 
						|
fn test_beaware_for_argument_names_with_same_prefix_inverse() {
 | 
						|
  mut fp := flag.new_flag_parser([
 | 
						|
    '--shorter=7',
 | 
						|
    '--short', '5', 
 | 
						|
    ])
 | 
						|
  
 | 
						|
  assert 5 == fp.int('short', 666, '')
 | 
						|
    && 7 == fp.int('shorter', 666, '')
 | 
						|
}
 | 
						|
 | 
						|
fn test_allow_to_skip_executable_path() {
 | 
						|
  mut fp := flag.new_flag_parser(['./path/to/execuable'])
 | 
						|
  
 | 
						|
  fp.skip_executable()
 | 
						|
  
 | 
						|
  args := fp.finalize() or {
 | 
						|
    assert false
 | 
						|
    return
 | 
						|
  }
 | 
						|
  assert !args.contains('./path/to/execuable')
 | 
						|
}
 | 
						|
 | 
						|
fn test_none_flag_arguments_are_allowed() {
 | 
						|
  mut fp := flag.new_flag_parser([
 | 
						|
    'file1', '--an_int=2', 'file2', 'file3', '--bool_without', 'file4', '--outfile', 'outfile'])
 | 
						|
  
 | 
						|
  assert 2 == fp.int('an_int', 666, '')
 | 
						|
    && 'outfile' == fp.string('outfile', 'bad', '')
 | 
						|
    && true == fp.bool('bool_without', false, '')
 | 
						|
}
 | 
						|
 | 
						|
fn test_finalize_returns_none_flag_arguments_ordered() {
 | 
						|
  mut fp := flag.new_flag_parser(['d', 'b', 'x', 'a', '--outfile', 'outfile'])
 | 
						|
  fp.string('outfile', 'bad', '')
 | 
						|
 | 
						|
  finalized := fp.finalize() or {
 | 
						|
    assert false
 | 
						|
    return
 | 
						|
  }
 | 
						|
 | 
						|
  expected := ['d', 'b', 'x', 'a']
 | 
						|
  mut all_as_expected := true 
 | 
						|
  for i, v in finalized {
 | 
						|
    all_as_expected = all_as_expected && v == expected[i]
 | 
						|
  }
 | 
						|
  assert all_as_expected
 | 
						|
}
 | 
						|
 | 
						|
fn test_finalize_returns_error_for_unknown_flags() {
 | 
						|
  mut fp := flag.new_flag_parser(['--known', '--unknown'])
 | 
						|
  
 | 
						|
  fp.bool('known', false, '')
 | 
						|
 | 
						|
  finalized := fp.finalize() or {
 | 
						|
    assert err == 'Unknown argument \'unknown\''
 | 
						|
    return
 | 
						|
  }
 | 
						|
  assert finalized.len < 0 // expect error to be returned
 | 
						|
}
 | 
						|
 | 
						|
fn test_allow_to_build_usage_message() {
 | 
						|
  mut fp := flag.new_flag_parser([]string)
 | 
						|
  fp.application('flag_tool')
 | 
						|
  fp.version('v0.0.0')
 | 
						|
  fp.description('some short information about this tool')
 | 
						|
 | 
						|
  fp.int('an_int', 666, 'some int to define')
 | 
						|
  fp.bool('a_bool', false, 'some bool to define')
 | 
						|
  fp.bool('bool_without_but_really_big', false, 'this should appear on the next line')
 | 
						|
  fp.float('a_float', 1.0, 'some float as well')
 | 
						|
  fp.string('a_string', 'not_stuff', 'your credit card number')
 | 
						|
  
 | 
						|
  usage := fp.usage()
 | 
						|
  mut all_strings_found := true
 | 
						|
  for s in ['flag_tool', 'v0.0.0', 
 | 
						|
            'an_int <int>', 'a_bool', 'bool_without', 'a_float <float>', 'a_string <arg>', 
 | 
						|
            'some int to define',
 | 
						|
            'some bool to define',
 | 
						|
            'this should appear on the next line',
 | 
						|
            'some float as well',
 | 
						|
            'your credit card number',
 | 
						|
            'usage', 'options:', 'description:',
 | 
						|
            'some short information about this tool'] {
 | 
						|
    if !usage.contains(s) {
 | 
						|
      eprintln(' missing \'$s\' in usage message')
 | 
						|
      all_strings_found = false
 | 
						|
    }
 | 
						|
  }
 | 
						|
  assert all_strings_found
 | 
						|
}
 | 
						|
 | 
						|
fn test_if_no_description_given_usage_message_does_not_contain_descpription() {
 | 
						|
  mut fp := flag.new_flag_parser([]string)
 | 
						|
  fp.application('flag_tool')
 | 
						|
  fp.version('v0.0.0')
 | 
						|
 | 
						|
  fp.bool('a_bool', false, '')
 | 
						|
  
 | 
						|
  assert !fp.usage().contains('description:')
 | 
						|
}
 | 
						|
 | 
						|
fn test_if_no_options_given_usage_message_does_not_contain_options() {
 | 
						|
  mut fp := flag.new_flag_parser([]string)
 | 
						|
  fp.application('flag_tool')
 | 
						|
  fp.version('v0.0.0')
 | 
						|
  
 | 
						|
  assert !fp.usage().contains('options:')
 | 
						|
}
 |