From 56ea693084029e3e5d2b60fe9860b4ca3059c12a Mon Sep 17 00:00:00 2001 From: Alexander Kuvaev Date: Fri, 21 Aug 2015 23:55:13 +0300 Subject: [PATCH] tests: tests for flag using --- src/lib.rs | 45 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) diff --git a/src/lib.rs b/src/lib.rs index c87df663..916de169 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1183,5 +1183,50 @@ mod tests { assert_eq!(m.value_of("color").unwrap(), "other"); } + #[test] + fn flag_using_short() { + let m = App::new("flag") + .args(vec![ + Arg::from_usage("-f, --flag 'some flag'"), + Arg::from_usage("-c, --color 'some other flag'") + ]) + .get_matches_from(vec!["", "-f", "-c"]); + assert!(m.is_present("flag")); + assert!(m.is_present("color")); + } + + #[test] + fn flag_using_long() { + let m = App::new("flag") + .args(vec![ + Arg::from_usage("--flag 'some flag'"), + Arg::from_usage("--color 'some other flag'") + ]) + .get_matches_from(vec!["", "--flag", "--color"]); + assert!(m.is_present("flag")); + assert!(m.is_present("color")); + } + + #[test] + fn flag_using_mixed() { + let m = App::new("flag") + .args(vec![ + Arg::from_usage("-f, --flag 'some flag'"), + Arg::from_usage("-c, --color 'some other flag'") + ]) + .get_matches_from(vec!["", "-f", "--color"]); + assert!(m.is_present("flag")); + assert!(m.is_present("color")); + + let m = App::new("flag") + .args(vec![ + Arg::from_usage("-f, --flag 'some flag'"), + Arg::from_usage("-c, --color 'some other flag'") + ]) + .get_matches_from(vec!["", "--flag", "-c"]); + assert!(m.is_present("flag")); + assert!(m.is_present("color")); + } + } \ No newline at end of file