mirror of
https://github.com/clap-rs/clap
synced 2025-01-07 10:18:48 +00:00
648 lines
18 KiB
Rust
648 lines
18 KiB
Rust
extern crate clap;
|
|
|
|
use clap::{App, Arg, ErrorKind, SubCommand};
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_long() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.long("option")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"--option", "val1",
|
|
"--option", "val2",
|
|
"--option", "val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 3);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_with_subcmd() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.long("option")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true))
|
|
.subcommand(SubCommand::with_name("foo"))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"--option", "val1",
|
|
"val2", "foo"
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2"]);
|
|
assert_eq!(m.subcommand_name(), Some("foo"));
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_short() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
"-o", "val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 3);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_mixed() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.long("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"--option", "val2",
|
|
"--option", "val3",
|
|
"-o", "val4",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 4);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3", "val4"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_exact_exact() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true)
|
|
.number_of_values(3))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
"-o", "val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 3);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_exact_less() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true)
|
|
.number_of_values(3))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
]);
|
|
|
|
assert!(m.is_err());
|
|
assert_eq!(m.unwrap_err().kind, ErrorKind::WrongNumberOfValues);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_exact_more() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true)
|
|
.number_of_values(3))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
"-o", "val3",
|
|
"-o", "val4",
|
|
]);
|
|
|
|
assert!(m.is_err());
|
|
assert_eq!(m.unwrap_err().kind, ErrorKind::WrongNumberOfValues);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_min_exact() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true)
|
|
.min_values(3))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
"-o", "val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 3);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_min_less() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true)
|
|
.min_values(3))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
]);
|
|
|
|
assert!(m.is_err());
|
|
assert_eq!(m.unwrap_err().kind, ErrorKind::TooFewValues);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_min_more() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true)
|
|
.min_values(3))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
"-o", "val3",
|
|
"-o", "val4",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 4);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3", "val4"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_max_exact() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true)
|
|
.max_values(3))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
"-o", "val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 3);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_max_less() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true)
|
|
.max_values(3))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 2);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_option_max_more() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true)
|
|
.max_values(3))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o", "val1",
|
|
"-o", "val2",
|
|
"-o", "val3",
|
|
"-o", "val4",
|
|
]);
|
|
|
|
assert!(m.is_err());
|
|
assert_eq!(m.unwrap_err().kind, ErrorKind::TooManyValues);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2", "val3"]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("pos"));
|
|
assert_eq!(m.occurrences_of("pos"), 3);
|
|
assert_eq!(m.values_of("pos").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional_exact_exact() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.number_of_values(3))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2", "val3"]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("pos"));
|
|
assert_eq!(m.occurrences_of("pos"), 3);
|
|
assert_eq!(m.values_of("pos").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional_exact_less() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.number_of_values(3))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2"]);
|
|
|
|
assert!(m.is_err());
|
|
assert_eq!(m.unwrap_err().kind, ErrorKind::WrongNumberOfValues);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional_exact_more() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.number_of_values(3))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2", "val3", "val4"]);
|
|
|
|
assert!(m.is_err());
|
|
assert_eq!(m.unwrap_err().kind, ErrorKind::WrongNumberOfValues);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional_min_exact() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.min_values(3))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2", "val3"]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("pos"));
|
|
assert_eq!(m.occurrences_of("pos"), 3);
|
|
assert_eq!(m.values_of("pos").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional_min_less() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.min_values(3))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2"]);
|
|
|
|
assert!(m.is_err());
|
|
assert_eq!(m.unwrap_err().kind, ErrorKind::TooFewValues);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional_min_more() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.min_values(3))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2", "val3", "val4"]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("pos"));
|
|
assert_eq!(m.occurrences_of("pos"), 4);
|
|
assert_eq!(m.values_of("pos").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3", "val4"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional_max_exact() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.max_values(3))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2", "val3"]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("pos"));
|
|
assert_eq!(m.occurrences_of("pos"), 3);
|
|
assert_eq!(m.values_of("pos").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional_max_less() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.max_values(3))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2"]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("pos"));
|
|
assert_eq!(m.occurrences_of("pos"), 2);
|
|
assert_eq!(m.values_of("pos").unwrap().collect::<Vec<_>>(), ["val1", "val2"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_of_positional_max_more() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("pos")
|
|
.help("multiple positionals")
|
|
.max_values(3))
|
|
.get_matches_from_safe(vec!["myprog", "val1", "val2", "val3", "val4"]);
|
|
|
|
assert!(m.is_err());
|
|
assert_eq!(m.unwrap_err().kind, ErrorKind::TooManyValues);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_sep_long_equals() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.long("option")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"--option=val1,val2,val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_sep_long_space() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.long("option")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"--option",
|
|
"val1,val2,val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_sep_short_equals() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o=val1,val2,val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_sep_short_space() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-o",
|
|
"val1,val2,val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_sep_short_no_space() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.short("o")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"-oval1,val2,val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_sep_positional() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.help("multiple options")
|
|
.multiple(true))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"val1,val2,val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_different_sep() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.long("option")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.value_delimiter(";"))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"--option=val1;val2;val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_different_sep_positional() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.help("multiple options")
|
|
.value_delimiter(";"))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"val1;val2;val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.values_of("option").unwrap().collect::<Vec<_>>(), ["val1", "val2", "val3"]);
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_no_sep() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.long("option")
|
|
.help("multiple options")
|
|
.takes_value(true)
|
|
.use_delimiter(false))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"--option=val1,val2,val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.value_of("option").unwrap(), "val1,val2,val3");
|
|
}
|
|
|
|
#[test]
|
|
fn multiple_values_no_sep_positional() {
|
|
let m = App::new("multiple_values")
|
|
.arg(Arg::with_name("option")
|
|
.help("multiple options")
|
|
.use_delimiter(false))
|
|
.get_matches_from_safe(vec![
|
|
"",
|
|
"val1,val2,val3",
|
|
]);
|
|
|
|
assert!(m.is_ok());
|
|
let m = m.unwrap();
|
|
|
|
assert!(m.is_present("option"));
|
|
assert_eq!(m.occurrences_of("option"), 1);
|
|
assert_eq!(m.value_of("option").unwrap(), "val1,val2,val3");
|
|
}
|