2020-10-06 11:47:50 +00:00
|
|
|
mod utils;
|
2020-03-19 07:13:02 +00:00
|
|
|
use clap::{App, Arg};
|
2015-08-27 21:03:45 +00:00
|
|
|
|
2020-10-06 11:47:50 +00:00
|
|
|
const USE_FLAG_AS_ARGUMENT: &str =
|
|
|
|
"error: Found argument '--another-flag' which wasn't expected, or isn't valid in this context
|
|
|
|
|
2020-10-09 16:31:00 +00:00
|
|
|
\tIf you tried to supply `--another-flag` as a value rather than a flag, use `-- --another-flag`
|
2020-10-06 11:47:50 +00:00
|
|
|
|
|
|
|
USAGE:
|
|
|
|
mycat [FLAGS] [filename]
|
|
|
|
|
|
|
|
For more information try --help";
|
|
|
|
|
2015-08-27 21:03:45 +00:00
|
|
|
#[test]
|
|
|
|
fn flag_using_short() {
|
|
|
|
let m = App::new("flag")
|
2016-01-21 06:48:30 +00:00
|
|
|
.args(&[
|
2018-04-21 18:59:19 +00:00
|
|
|
Arg::from("-f, --flag 'some flag'"),
|
|
|
|
Arg::from("-c, --color 'some other flag'"),
|
2018-01-25 04:05:05 +00:00
|
|
|
])
|
2016-01-25 20:56:37 +00:00
|
|
|
.get_matches_from(vec!["", "-f", "-c"]);
|
2015-08-27 21:03:45 +00:00
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert!(m.is_present("color"));
|
|
|
|
}
|
|
|
|
|
2016-02-02 12:43:53 +00:00
|
|
|
#[test]
|
|
|
|
fn lots_o_flags_sep() {
|
|
|
|
let r = App::new("opts")
|
2018-04-21 18:59:19 +00:00
|
|
|
.arg(Arg::from("-o... 'some flag'"))
|
2018-10-19 20:42:13 +00:00
|
|
|
.try_get_matches_from(vec![
|
2018-01-25 04:05:05 +00:00
|
|
|
"", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o", "-o",
|
|
|
|
"-o", "-o", "-o",
|
|
|
|
]);
|
2018-01-31 20:15:01 +00:00
|
|
|
assert!(r.is_ok(), "{:?}", r.unwrap_err().kind);
|
2016-02-02 12:43:53 +00:00
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.occurrences_of("o"), 297); // i.e. more than u8
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn lots_o_flags_combined() {
|
|
|
|
let r = App::new("opts")
|
2018-04-21 18:59:19 +00:00
|
|
|
.arg(Arg::from("-o... 'some flag'"))
|
2018-10-19 20:42:13 +00:00
|
|
|
.try_get_matches_from(vec![
|
2018-01-25 04:05:05 +00:00
|
|
|
"",
|
2016-02-02 12:43:53 +00:00
|
|
|
"-oooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo",
|
|
|
|
"-oooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo",
|
|
|
|
"-oooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo",
|
|
|
|
"-oooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo",
|
|
|
|
"-ooooooooooooooooooooooooooooooooooooooooo",
|
2018-01-25 04:05:05 +00:00
|
|
|
]);
|
2018-01-31 20:15:01 +00:00
|
|
|
assert!(r.is_ok(), "{:?}", r.unwrap_err().kind);
|
2016-02-02 12:43:53 +00:00
|
|
|
let m = r.unwrap();
|
|
|
|
assert!(m.is_present("o"));
|
|
|
|
assert_eq!(m.occurrences_of("o"), 297); // i.e. more than u8
|
|
|
|
}
|
|
|
|
|
2015-08-27 21:03:45 +00:00
|
|
|
#[test]
|
|
|
|
fn flag_using_long() {
|
|
|
|
let m = App::new("flag")
|
2016-01-21 06:48:30 +00:00
|
|
|
.args(&[
|
2018-04-21 18:59:19 +00:00
|
|
|
Arg::from("--flag 'some flag'"),
|
|
|
|
Arg::from("--color 'some other flag'"),
|
2018-01-25 04:05:05 +00:00
|
|
|
])
|
2016-01-25 20:56:37 +00:00
|
|
|
.get_matches_from(vec!["", "--flag", "--color"]);
|
2015-08-27 21:03:45 +00:00
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert!(m.is_present("color"));
|
|
|
|
}
|
|
|
|
|
2021-07-24 20:58:42 +00:00
|
|
|
#[test]
|
|
|
|
fn flag_using_long_with_literals() {
|
|
|
|
let m = App::new("flag")
|
|
|
|
.args(&[
|
|
|
|
Arg::from("--flag 'some flag'"),
|
|
|
|
Arg::from("--color 'some other flag'"),
|
|
|
|
Arg::from("--sky 'a third flag'"),
|
|
|
|
Arg::from("--rainbow 'yet another flag'").multiple_occurrences(true),
|
|
|
|
])
|
|
|
|
.get_matches_from(vec![
|
|
|
|
"",
|
|
|
|
"--flag=true",
|
|
|
|
"--color=false",
|
|
|
|
"--sky",
|
|
|
|
"--rainbow",
|
|
|
|
"--rainbow=false", // Clears the previous occurrence.
|
|
|
|
"--rainbow",
|
|
|
|
"--rainbow=true",
|
|
|
|
]);
|
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert!(!m.is_present("color"));
|
|
|
|
assert!(m.is_present("sky"));
|
|
|
|
assert!(m.is_present("rainbow"));
|
|
|
|
assert_eq!(m.occurrences_of("rainbow"), 2);
|
|
|
|
}
|
|
|
|
|
2015-08-27 21:03:45 +00:00
|
|
|
#[test]
|
|
|
|
fn flag_using_mixed() {
|
|
|
|
let m = App::new("flag")
|
2016-01-21 06:48:30 +00:00
|
|
|
.args(&[
|
2018-04-21 18:59:19 +00:00
|
|
|
Arg::from("-f, --flag 'some flag'"),
|
|
|
|
Arg::from("-c, --color 'some other flag'"),
|
2018-01-25 04:05:05 +00:00
|
|
|
])
|
2016-01-25 20:56:37 +00:00
|
|
|
.get_matches_from(vec!["", "-f", "--color"]);
|
2015-08-27 21:03:45 +00:00
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert!(m.is_present("color"));
|
|
|
|
|
|
|
|
let m = App::new("flag")
|
2016-01-21 06:48:30 +00:00
|
|
|
.args(&[
|
2018-04-21 18:59:19 +00:00
|
|
|
Arg::from("-f, --flag 'some flag'"),
|
|
|
|
Arg::from("-c, --color 'some other flag'"),
|
2018-01-25 04:05:05 +00:00
|
|
|
])
|
2016-01-25 20:56:37 +00:00
|
|
|
.get_matches_from(vec!["", "--flag", "-c"]);
|
2015-08-27 21:03:45 +00:00
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert!(m.is_present("color"));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn multiple_flags_in_single() {
|
|
|
|
let m = App::new("multe_flags")
|
2016-01-21 06:48:30 +00:00
|
|
|
.args(&[
|
2018-04-21 18:59:19 +00:00
|
|
|
Arg::from("-f, --flag 'some flag'"),
|
|
|
|
Arg::from("-c, --color 'some other flag'"),
|
|
|
|
Arg::from("-d, --debug 'another other flag'"),
|
2018-01-25 04:05:05 +00:00
|
|
|
])
|
2016-01-25 20:56:37 +00:00
|
|
|
.get_matches_from(vec!["", "-fcd"]);
|
2015-08-27 21:03:45 +00:00
|
|
|
assert!(m.is_present("flag"));
|
|
|
|
assert!(m.is_present("color"));
|
|
|
|
assert!(m.is_present("debug"));
|
|
|
|
}
|
2020-10-06 11:47:50 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn issue_1284_argument_in_flag_style() {
|
|
|
|
let app = App::new("mycat")
|
|
|
|
.arg(Arg::new("filename"))
|
|
|
|
.arg(Arg::new("a-flag").long("a-flag"));
|
|
|
|
|
|
|
|
let m = app
|
|
|
|
.clone()
|
|
|
|
.get_matches_from(vec!["", "--", "--another-flag"]);
|
|
|
|
assert_eq!(m.value_of("filename"), Some("--another-flag"));
|
|
|
|
|
|
|
|
let m = app.clone().get_matches_from(vec!["", "--a-flag"]);
|
|
|
|
assert!(m.is_present("a-flag"));
|
|
|
|
|
|
|
|
let m = app.clone().get_matches_from(vec!["", "--", "--a-flag"]);
|
|
|
|
assert_eq!(m.value_of("filename"), Some("--a-flag"));
|
|
|
|
|
|
|
|
assert!(utils::compare_output(
|
|
|
|
app,
|
|
|
|
"mycat --another-flag",
|
|
|
|
USE_FLAG_AS_ARGUMENT,
|
|
|
|
true
|
|
|
|
));
|
|
|
|
}
|
2021-01-23 07:18:55 +00:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn issue_2308_multiple_dashes() {
|
|
|
|
static MULTIPLE_DASHES: &str =
|
|
|
|
"error: Found argument '-----' which wasn't expected, or isn't valid in this context
|
|
|
|
|
|
|
|
If you tried to supply `-----` as a value rather than a flag, use `-- -----`
|
|
|
|
|
|
|
|
USAGE:
|
|
|
|
test <arg>
|
|
|
|
|
|
|
|
For more information try --help";
|
|
|
|
let app = App::new("test").arg(Arg::new("arg").takes_value(true).required(true));
|
|
|
|
|
|
|
|
assert!(utils::compare_output(
|
|
|
|
app,
|
|
|
|
"test -----",
|
|
|
|
MULTIPLE_DASHES,
|
|
|
|
true
|
|
|
|
));
|
|
|
|
}
|