use clap::{arg, Arg, ArgAction, Command}; #[test] fn single_short_arg_without_value() { let cmd = Command::new("cmd").ignore_errors(true).arg(arg!( -c --config [FILE] "Sets a custom config file" )); let r = cmd.try_get_matches_from(vec!["cmd", "-c" /* missing: , "config file" */]); assert!(r.is_ok(), "unexpected error: {r:?}"); let m = r.unwrap(); assert!(m.contains_id("config")); } #[test] fn single_long_arg_without_value() { let cmd = Command::new("cmd").ignore_errors(true).arg(arg!( -c --config [FILE] "Sets a custom config file" )); let r = cmd.try_get_matches_from(vec!["cmd", "--config" /* missing: , "config file" */]); assert!(r.is_ok(), "unexpected error: {r:?}"); let m = r.unwrap(); assert!(m.contains_id("config")); } #[test] fn multiple_args_and_final_arg_without_value() { let cmd = Command::new("cmd") .ignore_errors(true) .arg(arg!( -c --config [FILE] "Sets a custom config file" )) .arg(arg!( -x --stuff [FILE] "Sets a custom stuff file" )) .arg(arg!(f: -f "Flag").action(ArgAction::SetTrue)); let r = cmd.try_get_matches_from(vec![ "cmd", "-c", "file", "-f", "-x", /* missing: , "some stuff" */ ]); assert!(r.is_ok(), "unexpected error: {r:?}"); let m = r.unwrap(); assert_eq!( m.get_one::("config").map(|v| v.as_str()), Some("file") ); assert!(*m.get_one::("f").expect("defaulted by clap")); assert_eq!(m.get_one::("stuff").map(|v| v.as_str()), None); } #[test] fn multiple_args_and_intermittent_arg_without_value() { let cmd = Command::new("cmd") .ignore_errors(true) .arg(arg!( -c --config[FILE] "Sets a custom config file" )) .arg(arg!( -x --stuff[FILE] "Sets a custom stuff file" )) .arg(arg!(f: -f "Flag").action(ArgAction::SetTrue)); let r = cmd.try_get_matches_from(vec![ "cmd", "-x", /* missing: ,"some stuff" */ "-c", "file", "-f", ]); assert!(r.is_ok(), "unexpected error: {r:?}"); let m = r.unwrap(); assert_eq!( m.get_one::("config").map(|v| v.as_str()), Some("file") ); assert!(*m.get_one::("f").expect("defaulted by clap")); assert_eq!(m.get_one::("stuff").map(|v| v.as_str()), None); } #[test] fn subcommand() { let cmd = Command::new("test") .ignore_errors(true) .subcommand( Command::new("some") .arg( Arg::new("test") .short('t') .long("test") .action(ArgAction::Set) .help("testing testing"), ) .arg( Arg::new("stuff") .short('x') .long("stuff") .action(ArgAction::Set) .help("stuf value"), ), ) .arg(Arg::new("other").long("other")); let m = cmd .try_get_matches_from(vec![ "myprog", "some", "--test", /* missing: ,"some val" */ "-x", "some other val", ]) .unwrap(); assert_eq!(m.subcommand_name().unwrap(), "some"); let sub_m = m.subcommand_matches("some").unwrap(); assert!( sub_m.contains_id("test"), "expected subcommand to be present due to partial parsing" ); assert_eq!(sub_m.get_one::("test").map(|v| v.as_str()), None); assert_eq!( sub_m.get_one::("stuff").map(|v| v.as_str()), Some("some other val") ); }