2015-08-27 21:03:45 +00:00
|
|
|
extern crate clap;
|
2016-05-10 02:46:09 +00:00
|
|
|
extern crate regex;
|
|
|
|
|
|
|
|
include!("../clap-test.rs");
|
2015-08-27 21:03:45 +00:00
|
|
|
|
2016-06-30 03:01:41 +00:00
|
|
|
use clap::{App, Arg, ErrorKind};
|
2015-08-27 21:03:45 +00:00
|
|
|
|
2016-02-04 06:34:46 +00:00
|
|
|
#[test]
|
|
|
|
fn stdin_char() {
|
|
|
|
let r = App::new("opts")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-f [flag] 'some flag'"))
|
2016-02-04 06:34:46 +00:00
|
|
|
.get_matches_from_safe(vec!["", "-f", "-"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("f"));
|
|
|
|
assert_eq!(m.value_of("f").unwrap(), "-");
|
|
|
|
}
|
|
|
|
|
2015-08-27 21:03:45 +00:00
|
|
|
#[test]
|
|
|
|
fn opts_using_short() {
|
2016-01-26 07:05:32 +00:00
|
|
|
let r = App::new("opts")
|
2016-12-30 21:25:48 +00:00
|
|
|
.args(&[Arg::from_usage("-f [flag] 'some flag'"),
|
|
|
|
Arg::from_usage("-c [color] 'some other flag'")])
|
2016-01-26 07:05:32 +00:00
|
|
|
.get_matches_from_safe(vec!["", "-f", "some", "-c", "other"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
2016-01-25 20:56:37 +00:00
|
|
|
assert!(m.is_present("f"));
|
|
|
|
assert_eq!(m.value_of("f").unwrap(), "some");
|
|
|
|
assert!(m.is_present("c"));
|
|
|
|
assert_eq!(m.value_of("c").unwrap(), "other");
|
2015-08-27 21:03:45 +00:00
|
|
|
}
|
|
|
|
|
2016-02-02 12:43:53 +00:00
|
|
|
#[test]
|
|
|
|
fn lots_o_vals() {
|
|
|
|
let r = App::new("opts")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt]... 'some opt'"))
|
|
|
|
.get_matches_from_safe(vec!["", "-o", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some", "some", "some", "some",
|
|
|
|
"some", "some", "some", "some"]);
|
2016-02-02 12:43:53 +00:00
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.values_of("o").unwrap().collect::<Vec<_>>().len(), 297); // i.e. more than u8
|
|
|
|
}
|
|
|
|
|
2015-08-27 21:03:45 +00:00
|
|
|
#[test]
|
|
|
|
fn opts_using_long_space() {
|
2016-01-26 07:05:32 +00:00
|
|
|
let r = App::new("opts")
|
2016-12-30 21:25:48 +00:00
|
|
|
.args(&[Arg::from_usage("--flag [flag] 'some flag'"),
|
|
|
|
Arg::from_usage("--color [color] 'some other flag'")])
|
2016-01-26 07:05:32 +00:00
|
|
|
.get_matches_from_safe(vec!["", "--flag", "some", "--color", "other"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
2015-08-27 21:03:45 +00:00
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert_eq!(m.value_of("flag").unwrap(), "some");
|
|
|
|
assert!(m.is_present("color"));
|
|
|
|
assert_eq!(m.value_of("color").unwrap(), "other");
|
|
|
|
}
|
|
|
|
|
2016-03-30 02:31:40 +00:00
|
|
|
#[test]
|
|
|
|
fn opts_with_empty_values() {
|
|
|
|
let r = App::new("opts")
|
|
|
|
.arg_from_usage("--flag [flag]... 'some flag'")
|
|
|
|
.get_matches_from_safe(vec!["", "--flag", "", "test"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("flag"));
|
2016-12-30 21:25:48 +00:00
|
|
|
assert_eq!(m.values_of("flag").unwrap().collect::<Vec<_>>(),
|
|
|
|
["", "test"]);
|
2016-03-30 02:31:40 +00:00
|
|
|
}
|
|
|
|
|
2015-08-27 21:03:45 +00:00
|
|
|
#[test]
|
|
|
|
fn opts_using_long_equals() {
|
2016-01-26 07:05:32 +00:00
|
|
|
let r = App::new("opts")
|
2016-12-30 21:25:48 +00:00
|
|
|
.args(&[Arg::from_usage("--flag [flag] 'some flag'"),
|
|
|
|
Arg::from_usage("--color [color] 'some other flag'")])
|
2016-01-26 07:05:32 +00:00
|
|
|
.get_matches_from_safe(vec!["", "--flag=some", "--color=other"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
2015-08-27 21:03:45 +00:00
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert_eq!(m.value_of("flag").unwrap(), "some");
|
|
|
|
assert!(m.is_present("color"));
|
|
|
|
assert_eq!(m.value_of("color").unwrap(), "other");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn opts_using_mixed() {
|
2016-01-26 07:05:32 +00:00
|
|
|
let r = App::new("opts")
|
2016-12-30 21:25:48 +00:00
|
|
|
.args(&[Arg::from_usage("-f, --flag [flag] 'some flag'"),
|
|
|
|
Arg::from_usage("-c, --color [color] 'some other flag'")])
|
2016-01-26 07:05:32 +00:00
|
|
|
.get_matches_from_safe(vec!["", "-f", "some", "--color", "other"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
2015-08-27 21:03:45 +00:00
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert_eq!(m.value_of("flag").unwrap(), "some");
|
|
|
|
assert!(m.is_present("color"));
|
|
|
|
assert_eq!(m.value_of("color").unwrap(), "other");
|
2016-01-26 07:05:32 +00:00
|
|
|
}
|
2015-08-27 21:03:45 +00:00
|
|
|
|
2016-01-26 07:05:32 +00:00
|
|
|
#[test]
|
|
|
|
fn opts_using_mixed2() {
|
|
|
|
let r = App::new("opts")
|
2016-12-30 21:25:48 +00:00
|
|
|
.args(&[Arg::from_usage("-f, --flag [flag] 'some flag'"),
|
|
|
|
Arg::from_usage("-c, --color [color] 'some other flag'")])
|
2016-01-26 07:05:32 +00:00
|
|
|
.get_matches_from_safe(vec!["", "--flag=some", "-c", "other"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
2015-08-27 21:03:45 +00:00
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert_eq!(m.value_of("flag").unwrap(), "some");
|
|
|
|
assert!(m.is_present("color"));
|
|
|
|
assert_eq!(m.value_of("color").unwrap(), "other");
|
2016-01-21 05:18:53 +00:00
|
|
|
}
|
2016-02-09 14:05:19 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn default_values_user_value() {
|
|
|
|
let r = App::new("df")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt] 'some opt'").default_value("default"))
|
2016-02-09 14:05:19 +00:00
|
|
|
.get_matches_from_safe(vec!["", "-o", "value"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.value_of("o").unwrap(), "value");
|
|
|
|
}
|
2016-05-09 03:20:50 +00:00
|
|
|
|
2016-06-29 17:30:30 +00:00
|
|
|
#[test]
|
|
|
|
fn multiple_vals_pos_arg_equals() {
|
|
|
|
let r = App::new("mvae")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt]... 'some opt'"))
|
|
|
|
.arg(Arg::from_usage("[file] 'some file'"))
|
2016-06-29 17:30:30 +00:00
|
|
|
.get_matches_from_safe(vec!["", "-o=1", "some"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.value_of("o").unwrap(), "1");
|
|
|
|
assert!(m.is_present("file"));
|
|
|
|
assert_eq!(m.value_of("file").unwrap(), "some");
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn multiple_vals_pos_arg_delim() {
|
|
|
|
let r = App::new("mvae")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt]... 'some opt'"))
|
|
|
|
.arg(Arg::from_usage("[file] 'some file'"))
|
2016-06-29 17:30:30 +00:00
|
|
|
.get_matches_from_safe(vec!["", "-o", "1,2", "some"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.values_of("o").unwrap().collect::<Vec<_>>(), &["1", "2"]);
|
|
|
|
assert!(m.is_present("file"));
|
|
|
|
assert_eq!(m.value_of("file").unwrap(), "some");
|
|
|
|
}
|
|
|
|
|
2016-06-30 03:01:41 +00:00
|
|
|
#[test]
|
|
|
|
fn require_delims_no_delim() {
|
|
|
|
let r = App::new("mvae")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt]... 'some opt'").require_delimiter(true))
|
|
|
|
.arg(Arg::from_usage("[file] 'some file'"))
|
2016-06-30 03:01:41 +00:00
|
|
|
.get_matches_from_safe(vec!["mvae", "-o", "1", "2", "some"]);
|
|
|
|
assert!(r.is_err());
|
|
|
|
let err = r.unwrap_err();
|
|
|
|
assert_eq!(err.kind, ErrorKind::UnknownArgument);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn require_delims() {
|
|
|
|
let r = App::new("mvae")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt]... 'some opt'").require_delimiter(true))
|
|
|
|
.arg(Arg::from_usage("[file] 'some file'"))
|
2016-06-30 03:01:41 +00:00
|
|
|
.get_matches_from_safe(vec!["", "-o", "1,2", "some"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.values_of("o").unwrap().collect::<Vec<_>>(), &["1", "2"]);
|
|
|
|
assert!(m.is_present("file"));
|
|
|
|
assert_eq!(m.value_of("file").unwrap(), "some");
|
|
|
|
}
|
|
|
|
|
2016-11-20 01:40:53 +00:00
|
|
|
#[test]
|
|
|
|
fn leading_hyphen_pass() {
|
|
|
|
let r = App::new("mvae")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt]... 'some opt'").allow_hyphen_values(true))
|
2016-11-20 01:40:53 +00:00
|
|
|
.get_matches_from_safe(vec!["", "-o", "-2", "3"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.values_of("o").unwrap().collect::<Vec<_>>(), &["-2", "3"]);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn leading_hyphen_fail() {
|
|
|
|
let r = App::new("mvae")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt] 'some opt'"))
|
2016-11-20 01:40:53 +00:00
|
|
|
.get_matches_from_safe(vec!["", "-o", "-2"]);
|
|
|
|
assert!(r.is_err());
|
|
|
|
let m = r.unwrap_err();
|
|
|
|
assert_eq!(m.kind, ErrorKind::UnknownArgument);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn leading_hyphen_with_flag_after() {
|
|
|
|
let r = App::new("mvae")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt]... 'some opt'").allow_hyphen_values(true))
|
2016-11-20 01:40:53 +00:00
|
|
|
.arg_from_usage("-f 'some flag'")
|
|
|
|
.get_matches_from_safe(vec!["", "-o", "-2", "-f"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.values_of("o").unwrap().collect::<Vec<_>>(), &["-2", "-f"]);
|
|
|
|
assert!(!m.is_present("f"));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn leading_hyphen_with_flag_before() {
|
|
|
|
let r = App::new("mvae")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt]... 'some opt'").allow_hyphen_values(true))
|
2016-11-20 01:40:53 +00:00
|
|
|
.arg_from_usage("-f 'some flag'")
|
|
|
|
.get_matches_from_safe(vec!["", "-f", "-o", "-2"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.values_of("o").unwrap().collect::<Vec<_>>(), &["-2"]);
|
|
|
|
assert!(m.is_present("f"));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn leading_hyphen_with_only_pos_follows() {
|
|
|
|
let r = App::new("mvae")
|
2016-12-30 21:25:48 +00:00
|
|
|
.arg(Arg::from_usage("-o [opt]... 'some opt'").allow_hyphen_values(true))
|
2016-11-20 01:40:53 +00:00
|
|
|
.arg_from_usage("[arg] 'some arg'")
|
|
|
|
.get_matches_from_safe(vec!["", "-o", "-2", "--", "val"]);
|
|
|
|
assert!(r.is_ok());
|
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.values_of("o").unwrap().collect::<Vec<_>>(), &["-2"]);
|
|
|
|
assert_eq!(m.value_of("arg"), Some("val"));
|
|
|
|
}
|
|
|
|
|
2016-05-09 03:20:50 +00:00
|
|
|
#[test]
|
2016-10-05 18:06:32 +00:00
|
|
|
#[cfg(feature="suggestions")]
|
2016-05-09 03:20:50 +00:00
|
|
|
fn did_you_mean() {
|
2016-12-30 21:25:48 +00:00
|
|
|
test::check_err_output(test::complex_app(),
|
|
|
|
"clap-test --optio=foo",
|
|
|
|
"error: Found argument '--optio' which wasn't expected, or isn't valid in this context
|
2016-07-05 20:01:04 +00:00
|
|
|
\tDid you mean --option?
|
2016-05-09 03:20:50 +00:00
|
|
|
|
|
|
|
USAGE:
|
|
|
|
clap-test --option <opt>...
|
|
|
|
|
2016-12-30 21:25:48 +00:00
|
|
|
For more information try --help",
|
|
|
|
true);
|
2016-05-09 03:20:50 +00:00
|
|
|
}
|
2016-12-30 21:25:48 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn issue_665() {
|
|
|
|
let res = App::new("tester")
|
|
|
|
.arg_from_usage("-v, --reroll-count=[N] 'Mark the patch series as PATCH vN'")
|
|
|
|
.arg(Arg::from_usage(
|
|
|
|
"--subject-prefix [Subject-Prefix] 'Use [Subject-Prefix] instead of the standard [PATCH] prefix'")
|
|
|
|
.empty_values(false))
|
|
|
|
.get_matches_from_safe(vec!["test", "--subject-prefix", "-v", "2"]);
|
|
|
|
|
|
|
|
assert!(res.is_err());
|
|
|
|
assert_eq!(res.unwrap_err().kind, ErrorKind::EmptyValue);
|
|
|
|
}
|