summaryrefslogtreecommitdiff
path: root/argparse/src/test_bool.rs
diff options
context:
space:
mode:
authorRobin Krahl <robin.krahl@ireas.org>2018-12-18 00:39:15 +0100
committerDaniel Mueller <deso@posteo.net>2018-12-21 18:41:19 -0800
commitd137415a69007a90569ebbf38a92424fba60b997 (patch)
tree08bdb1fc4f06bca29d36fdfc9e04c8c5c0086119 /argparse/src/test_bool.rs
parent170e1df9d96f628af8cf8107f29227b90ae9350b (diff)
downloadnitrocli-d137415a69007a90569ebbf38a92424fba60b997.tar.gz
nitrocli-d137415a69007a90569ebbf38a92424fba60b997.tar.bz2
Add argparse 0.2.2 as a dependency
This patch adds the crate rust-argparse [0] in version 0.2.2 as a dependency, as discussed in issue #4. [0] https://github.com/tailhook/rust-argparse Import subrepo argparse/:argparse at 0de60a5e6d9ee1a3570d6089afd3ccd6ed7480c5
Diffstat (limited to 'argparse/src/test_bool.rs')
-rw-r--r--argparse/src/test_bool.rs98
1 files changed, 98 insertions, 0 deletions
diff --git a/argparse/src/test_bool.rs b/argparse/src/test_bool.rs
new file mode 100644
index 0000000..a30cf3c
--- /dev/null
+++ b/argparse/src/test_bool.rs
@@ -0,0 +1,98 @@
+use parser::ArgumentParser;
+use super::Store;
+use super::{StoreTrue, StoreFalse};
+use test_parser::{check_ok};
+
+fn store_true(args: &[&str]) -> bool {
+ let mut verbose = false;
+ {
+ let mut ap = ArgumentParser::new();
+ ap.refer(&mut verbose)
+ .add_option(&["-t", "--true"], StoreTrue,
+ "Store true action");
+ check_ok(&ap, args);
+ }
+ return verbose;
+}
+
+#[test]
+fn test_store_true() {
+ assert!(!store_true(&["./argparse_test"]));
+ assert!(store_true(&["./argparse_test", "--true"]));
+}
+
+fn store_false(args: &[&str]) -> bool {
+ let mut verbose = true;
+ {
+ let mut ap = ArgumentParser::new();
+ ap.refer(&mut verbose)
+ .add_option(&["-f", "--false"], StoreFalse,
+ "Store false action");
+ check_ok(&ap, args);
+ }
+ return verbose;
+}
+#[test]
+fn test_store_false() {
+ assert!(store_false(&["./argparse_test"]));
+ assert!(!store_false(&["./argparse_test", "--false"]));
+}
+
+fn store_bool(args: &[&str]) -> bool {
+ let mut verbose = false;
+ {
+ let mut ap = ArgumentParser::new();
+ ap.refer(&mut verbose)
+ .add_option(&["-f", "--false"], StoreFalse,
+ "Store false action")
+ .add_option(&["-t", "--true"], StoreTrue,
+ "Store false action");
+ check_ok(&ap, args);
+ }
+ return verbose;
+}
+
+#[test]
+fn test_bool() {
+ assert!(!store_bool(&["./argparse_test"]));
+ assert!(store_bool(&["./argparse_test", "-t"]));
+ assert!(!store_bool(&["./argparse_test", "-f"]));
+ assert!(store_bool(&["./argparse_test", "-fft"]));
+ assert!(!store_bool(&["./argparse_test", "-fffft", "-f"]));
+ assert!(store_bool(&["./argparse_test", "--false", "-fffft", "-f",
+ "--true"]));
+}
+
+fn set_bool(args: &[&str]) -> bool {
+ let mut verbose = false;
+ {
+ let mut ap = ArgumentParser::new();
+ ap.refer(&mut verbose)
+ .add_option(&["-s", "--set"], Store,
+ "Set boolean value");
+ check_ok(&ap, args);
+ }
+ return verbose;
+}
+
+
+#[test]
+fn test_set_bool() {
+ assert!(!set_bool(&["./argparse_test"]));
+ assert!(set_bool(&["./argparse_test", "-strue"]));
+ assert!(!set_bool(&["./argparse_test", "-sfalse"]));
+
+ // Unfortunately other values do not work
+}
+
+#[test]
+#[should_panic(expected="Bad value yes")]
+fn test_bad_bools1() {
+ assert!(!set_bool(&["./argparse_test", "-syes"]));
+}
+
+#[test]
+#[should_panic(expected="Bad value no")]
+fn test_bad_bools2() {
+ assert!(!set_bool(&["./argparse_test", "-sno"]));
+}