summaryrefslogtreecommitdiff
path: root/argparse/src/test_help.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_help.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_help.rs')
-rw-r--r--argparse/src/test_help.rs154
1 files changed, 154 insertions, 0 deletions
diff --git a/argparse/src/test_help.rs b/argparse/src/test_help.rs
new file mode 100644
index 0000000..f23b14b
--- /dev/null
+++ b/argparse/src/test_help.rs
@@ -0,0 +1,154 @@
+use std::str::from_utf8;
+
+use parser::ArgumentParser;
+use super::{Store, List};
+
+#[test]
+fn test_empty() {
+ let mut ap = ArgumentParser::new();
+ let mut buf = Vec::<u8>::new();
+ ap.set_description("Test program");
+ assert!(ap.print_help("./argparse_test", &mut buf).is_ok());
+ assert_eq!("Usage:\n".to_string()
+ + " ./argparse_test\n"
+ + "\n"
+ + "Test program\n"
+ + "\n"
+ + "Optional arguments:\n"
+ + " -h,--help Show this help message and exit\n"
+ , from_utf8(&buf[..]).unwrap().to_string());
+}
+
+#[test]
+fn test_options() {
+ let mut val = 0;
+ let mut val2 = 0;
+ let mut ap = ArgumentParser::new();
+ ap.set_description("Test program. The description of the program is ought
+ to be very long, because we want to test how word wrapping works for
+ it. So some more text would be ok for the test");
+ ap.refer(&mut val)
+ .add_option(&["--value"], Store,
+ "Set integer value");
+ ap.refer(&mut val2)
+ .add_option(&["-L", "--long-option"], Store,
+ "Long option value");
+ let mut buf = Vec::<u8>::new();
+ assert!(ap.print_help("./argparse_test", &mut buf).is_ok());
+ assert_eq!("Usage:\n".to_string()
+ + " ./argparse_test [OPTIONS]
+
+Test program. The description of the program is ought to be very long, because
+we want to test how word wrapping works for it. So some more text would be ok
+for the test\n"
+ + "\n"
+ + "Optional arguments:\n"
+ + " -h,--help Show this help message and exit\n"
+ + " --value VALUE Set integer value\n"
+ + " -L,--long-option LONG_OPTION\n"
+ + " Long option value\n"
+ , from_utf8(&buf[..]).unwrap().to_string());
+}
+
+#[test]
+fn test_argument() {
+ let mut val = 0;
+ let mut ap = ArgumentParser::new();
+ ap.set_description("Test program");
+ ap.refer(&mut val)
+ .add_argument("value", Store,
+ "Integer value");
+ let mut buf = Vec::<u8>::new();
+ assert!(ap.print_help("./argparse_test", &mut buf).is_ok());
+ assert_eq!("Usage:\n".to_string()
+ + " ./argparse_test [VALUE]\n"
+ + "\n"
+ + "Test program\n"
+ + "\n"
+ + "Positional arguments:\n"
+ + " value Integer value\n"
+ + "\n"
+ + "Optional arguments:\n"
+ + " -h,--help Show this help message and exit\n"
+ , from_utf8(&buf[..]).unwrap().to_string());
+}
+
+#[test]
+fn test_arguments() {
+ let mut v1 = 0;
+ let mut v2 = Vec::<u32>::new();
+ let mut ap = ArgumentParser::new();
+ ap.set_description("Test program");
+ ap.refer(&mut v1)
+ .add_argument("v1", Store,
+ "Integer value 1");
+ ap.refer(&mut v2)
+ .add_argument("v2", List,
+ "More values");
+ let mut buf = Vec::<u8>::new();
+ assert!(ap.print_help("./argparse_test", &mut buf).is_ok());
+ assert_eq!("Usage:\n".to_string()
+ + " ./argparse_test [V1] [V2 ...]\n"
+ + "\n"
+ + "Test program\n"
+ + "\n"
+ + "Positional arguments:\n"
+ + " v1 Integer value 1\n"
+ + " v2 More values\n"
+ + "\n"
+ + "Optional arguments:\n"
+ + " -h,--help Show this help message and exit\n"
+ , from_utf8(&buf[..]).unwrap().to_string());
+}
+
+#[test]
+fn test_req_arguments() {
+ let mut v1 = 0;
+ let mut v2 = Vec::<u32>::new();
+ let mut ap = ArgumentParser::new();
+ ap.set_description("Test program");
+ ap.refer(&mut v1)
+ .add_argument("v1", Store,
+ "Integer value 1")
+ .required();
+ ap.refer(&mut v2)
+ .add_argument("v2", List,
+ "More values")
+ .required();
+ let mut buf = Vec::<u8>::new();
+ assert!(ap.print_help("./argparse_test", &mut buf).is_ok());
+ assert_eq!("Usage:\n".to_string()
+ + " ./argparse_test V1 V2 [...]\n"
+ + "\n"
+ + "Test program\n"
+ + "\n"
+ + "Positional arguments:\n"
+ + " v1 Integer value 1\n"
+ + " v2 More values\n"
+ + "\n"
+ + "Optional arguments:\n"
+ + " -h,--help Show this help message and exit\n"
+ , from_utf8(&buf[..]).unwrap().to_string());
+}
+
+#[test]
+fn test_metavar() {
+ let mut val2 = 0;
+ let mut ap = ArgumentParser::new();
+ ap.set_description("Test program.");
+ ap.refer(&mut val2)
+ .add_option(&["-L", "--long-option"], Store,
+ "Long option value")
+ .metavar("VAL");
+ let mut buf = Vec::<u8>::new();
+ assert!(ap.print_help("./argparse_test", &mut buf).is_ok());
+ assert_eq!("Usage:\n".to_string()
+ + " ./argparse_test [OPTIONS]\n"
+ + "\n"
+ + "Test program.\n"
+ + "\n"
+ + "Optional arguments:\n"
+ + " -h,--help Show this help message and exit\n"
+ + " -L,--long-option VAL Long option value\n"
+ , from_utf8(&buf[..]).unwrap().to_string());
+}