aboutsummaryrefslogtreecommitdiffhomepage
path: root/test
diff options
context:
space:
mode:
authorGravatar David Bremner <bremner@debian.org>2011-12-07 14:37:13 -0400
committerGravatar David Bremner <bremner@debian.org>2011-12-08 20:24:24 -0400
commit5800a44bd5b77390d2243426f0c82de4d0495a1c (patch)
treef20c58811ce59533a1cf05697fb21febdee66e1e /test
parent2cf7b27a0c4b4e746e2e40752c55ddb4d54798b2 (diff)
test: tests for command-line-arguments.c
This was needed because no current notmuch code exercises the NOTMUCH_OPT_STRING style arguments.
Diffstat (limited to 'test')
-rw-r--r--test/Makefile.local11
-rw-r--r--test/arg-test.c52
-rwxr-xr-xtest/argument-parsing16
-rwxr-xr-xtest/basic2
-rwxr-xr-xtest/notmuch-test1
5 files changed, 79 insertions, 3 deletions
diff --git a/test/Makefile.local b/test/Makefile.local
index bffbbdbd..6cb6c829 100644
--- a/test/Makefile.local
+++ b/test/Makefile.local
@@ -2,12 +2,17 @@
dir := test
+extra_cflags += -I.
+
smtp_dummy_srcs = \
$(notmuch_compat_srcs) \
$(dir)/smtp-dummy.c
smtp_dummy_modules = $(smtp_dummy_srcs:.c=.o)
+$(dir)/arg-test: $(dir)/arg-test.o command-line-arguments.o util/libutil.a
+ $(call quiet,CC) -I. $^ -o $@
+
$(dir)/smtp-dummy: $(smtp_dummy_modules)
$(call quiet,CC) $^ -o $@
@@ -16,11 +21,13 @@ $(dir)/symbol-test: $(dir)/symbol-test.o
.PHONY: test check
-test-binaries: $(dir)/smtp-dummy $(dir)/symbol-test
+test-binaries: $(dir)/arg-test $(dir)/smtp-dummy $(dir)/symbol-test
test: all test-binaries
@${dir}/notmuch-test $(OPTIONS)
check: test
-CLEAN := $(CLEAN) $(dir)/smtp-dummy $(dir)/smtp-dummy.o $(dir)/symbol-test $(dir)/symbol-test.o
+CLEAN := $(CLEAN) $(dir)/smtp-dummy $(dir)/smtp-dummy.o \
+ $(dir)/symbol-test $(dir)/symbol-test.o \
+ $(dir)/arg-test $(dir)/arg-test.o
diff --git a/test/arg-test.c b/test/arg-test.c
new file mode 100644
index 00000000..adc56e30
--- /dev/null
+++ b/test/arg-test.c
@@ -0,0 +1,52 @@
+#include <stdio.h>
+#include "command-line-arguments.h"
+
+
+int main(int argc, char **argv){
+
+ int opt_index=1;
+
+ int kw_val=0;
+ int int_val=0;
+ char *pos_arg1=NULL;
+ char *pos_arg2=NULL;
+ char *string_val=NULL;
+
+ notmuch_opt_desc_t options[] = {
+ { NOTMUCH_OPT_KEYWORD, &kw_val, "keyword", 'k',
+ (notmuch_keyword_t []){ { "one", 1 },
+ { "two", 2 },
+ { 0, 0 } } },
+ { NOTMUCH_OPT_INT, &int_val, "int", 'i', 0},
+ { NOTMUCH_OPT_STRING, &string_val, "string", 's', 0},
+ { NOTMUCH_OPT_POSITION, &pos_arg1, 0,0, 0},
+ { NOTMUCH_OPT_POSITION, &pos_arg2, 0,0, 0},
+ { 0, 0, 0, 0, 0 } };
+
+ opt_index = parse_arguments(argc, argv, options, 1);
+
+ if (opt_index < 0)
+ return 1;
+
+ if (kw_val)
+ printf("keyword %d\n", kw_val);
+
+ if (int_val)
+ printf("int %d\n", int_val);
+
+ if (string_val)
+ printf("string %s\n", string_val);
+
+ if (pos_arg1)
+ printf("positional arg 1 %s\n", pos_arg1);
+
+ if (pos_arg2)
+ printf("positional arg 2 %s\n", pos_arg1);
+
+
+ for ( ; opt_index < argc ; opt_index ++) {
+ printf("non parsed arg %d = %s\n", opt_index, argv[opt_index]);
+ }
+
+ return 0;
+}
diff --git a/test/argument-parsing b/test/argument-parsing
new file mode 100755
index 00000000..672de0b3
--- /dev/null
+++ b/test/argument-parsing
@@ -0,0 +1,16 @@
+#!/usr/bin/env bash
+test_description="argument parsing"
+. ./test-lib.sh
+
+test_begin_subtest "sanity check"
+$TEST_DIRECTORY/arg-test pos1 --keyword=one --string=foo pos2 --int=7 > OUTPUT
+cat <<EOF > EXPECTED
+keyword 1
+int 7
+string foo
+positional arg 1 pos1
+positional arg 2 pos1
+EOF
+test_expect_equal_file OUTPUT EXPECTED
+
+test_done
diff --git a/test/basic b/test/basic
index 4edf8315..d6aed24c 100755
--- a/test/basic
+++ b/test/basic
@@ -54,7 +54,7 @@ test_begin_subtest 'Ensure that all available tests will be run by notmuch-test'
eval $(sed -n -e '/^TESTS="$/,/^"$/p' $TEST_DIRECTORY/notmuch-test)
tests_in_suite=$(for i in $TESTS; do echo $i; done | sort)
available=$(find "$TEST_DIRECTORY" -maxdepth 1 -type f -executable -printf '%f\n' | \
- sed -r -e "/^(aggregate-results.sh|notmuch-test|smtp-dummy|test-verbose|symbol-test)$/d" | \
+ sed -r -e "/^(aggregate-results.sh|notmuch-test|smtp-dummy|test-verbose|symbol-test|arg-test)$/d" | \
sort)
test_expect_equal "$tests_in_suite" "$available"
diff --git a/test/notmuch-test b/test/notmuch-test
index 53ce355c..d05bb38b 100755
--- a/test/notmuch-test
+++ b/test/notmuch-test
@@ -48,6 +48,7 @@ TESTS="
search-folder-coherence
atomicity
python
+ argument-parsing
"
TESTS=${NOTMUCH_TESTS:=$TESTS}