summaryrefslogtreecommitdiff
path: root/test/testargs.c
diff options
context:
space:
mode:
authorrbb <rbb@13f79535-47bb-0310-9956-ffa450edef68>2002-12-06 16:04:58 +0000
committerrbb <rbb@13f79535-47bb-0310-9956-ffa450edef68>2002-12-06 16:04:58 +0000
commit427e4710e6fb6df71a170590ee8379a408db058a (patch)
tree4acd90dc14dbf416114b2fd0372018fab9c466e5 /test/testargs.c
parentd5582279a0dc8caecba845cf87c8d767b3bf97ae (diff)
downloadlibapr-427e4710e6fb6df71a170590ee8379a408db058a.tar.gz
Migreate testargs to the new test suite.
git-svn-id: http://svn.apache.org/repos/asf/apr/apr/trunk@64124 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'test/testargs.c')
-rw-r--r--test/testargs.c222
1 files changed, 190 insertions, 32 deletions
diff --git a/test/testargs.c b/test/testargs.c
index 1eb96a881..34915fdc0 100644
--- a/test/testargs.c
+++ b/test/testargs.c
@@ -52,65 +52,223 @@
* <http://www.apache.org/>.
*/
-#include "apr_file_io.h"
#include "apr_errno.h"
#include "apr_general.h"
-#include "apr_lib.h"
#include "apr_getopt.h"
-#include <stdio.h>
-#include <stdlib.h>
-#ifdef BEOS
-#include <unistd.h>
-#endif
+#include "apr_strings.h"
+#include "test_apr.h"
-static void maybe_arg(const char *arg)
+static void format_arg(char *str, char option, const char *arg)
{
if (arg) {
- printf(" with %s\n", arg);
+ apr_snprintf(str, 8196, "%soption: %c with %s\n", str, option, arg);
}
else {
- printf("\n");
+ apr_snprintf(str, 8196, "%soption: %c\n", str, option);
}
}
-int main(int argc, const char * const argv[])
+static void unknown_arg(void *str, const char *err, ...)
+{
+ va_list va;
+
+ va_start(va, err);
+ apr_vsnprintf(str, 8196, err, va);
+ va_end(va);
+}
+
+static void no_options_found(CuTest *tc)
{
- apr_pool_t *context;
+ int largc = 5;
+ const char * const largv[] = {"testprog", "-a", "-b", "-c", "-d"};
apr_getopt_t *opt;
+ apr_status_t rv;
char data;
const char *optarg;
+ char str[8196];
- apr_initialize();
- atexit(apr_terminate);
- apr_pool_create(&context, NULL);
-
- if (apr_getopt_init(&opt, context, argc, argv))
- {
- printf("failed to initialize opts");
- exit(1);
+ str[0] = '\0';
+ rv = apr_getopt_init(&opt, p, largc, largv);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ while (apr_getopt(opt, "abcd", &data, &optarg) == APR_SUCCESS) {
+ switch (data) {
+ case 'a':
+ case 'b':
+ case 'c':
+ case 'd':
+ default:
+ format_arg(str, data, optarg);
+ }
}
- while (apr_getopt(opt, "abc:d::", &data, &optarg) == APR_SUCCESS) {
+ CuAssertStrEquals(tc, "option: a\n"
+ "option: b\n"
+ "option: c\n"
+ "option: d\n", str);
+}
+
+static void no_options(CuTest *tc)
+{
+ int largc = 5;
+ const char * const largv[] = {"testprog", "-a", "-b", "-c", "-d"};
+ apr_getopt_t *opt;
+ apr_status_t rv;
+ char data;
+ const char *optarg;
+ char str[8196];
+
+ str[0] = '\0';
+ rv = apr_getopt_init(&opt, p, largc, largv);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ opt->errfn = unknown_arg;
+ opt->errarg = str;
+
+ while (apr_getopt(opt, "efgh", &data, &optarg) == APR_SUCCESS) {
switch (data) {
case 'a':
case 'b':
- printf("option %c\n", data);
- break;
case 'c':
- printf("option %c with %s\n", data, optarg);
- break;
case 'd':
- printf("option %c", data);
- maybe_arg(optarg);
+ format_arg(str, data, optarg);
+ break;
+ default:
+ break;
+ }
+ }
+ CuAssertStrEquals(tc, "testprog: illegal option -- a\n", str);
+}
+
+static void required_option(CuTest *tc)
+{
+ int largc = 3;
+ const char * const largv[] = {"testprog", "-a", "foo"};
+ apr_getopt_t *opt;
+ apr_status_t rv;
+ char data;
+ const char *optarg;
+ char str[8196];
+
+ str[0] = '\0';
+ rv = apr_getopt_init(&opt, p, largc, largv);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ opt->errfn = unknown_arg;
+ opt->errarg = str;
+
+ while (apr_getopt(opt, "a:", &data, &optarg) == APR_SUCCESS) {
+ switch (data) {
+ case 'a':
+ format_arg(str, data, optarg);
break;
default:
- printf("unknown option: %c", data);
- maybe_arg(optarg);
break;
}
}
+ CuAssertStrEquals(tc, "option: a with foo\n", str);
+}
+
+static void required_option_notgiven(CuTest *tc)
+{
+ int largc = 2;
+ const char * const largv[] = {"testprog", "-a"};
+ apr_getopt_t *opt;
+ apr_status_t rv;
+ char data;
+ const char *optarg;
+ char str[8196];
+
+ str[0] = '\0';
+ rv = apr_getopt_init(&opt, p, largc, largv);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ opt->errfn = unknown_arg;
+ opt->errarg = str;
+
+ while (apr_getopt(opt, "a:", &data, &optarg) == APR_SUCCESS) {
+ switch (data) {
+ case 'a':
+ format_arg(str, data, optarg);
+ break;
+ default:
+ break;
+ }
+ }
+ CuAssertStrEquals(tc, "testprog: option requires an argument -- a\n", str);
+}
+
+static void optional_option(CuTest *tc)
+{
+ int largc = 3;
+ const char * const largv[] = {"testprog", "-a", "foo"};
+ apr_getopt_t *opt;
+ apr_status_t rv;
+ char data;
+ const char *optarg;
+ char str[8196];
+
+ str[0] = '\0';
+ rv = apr_getopt_init(&opt, p, largc, largv);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ opt->errfn = unknown_arg;
+ opt->errarg = str;
+
+ while (apr_getopt(opt, "a::", &data, &optarg) == APR_SUCCESS) {
+ switch (data) {
+ case 'a':
+ format_arg(str, data, optarg);
+ break;
+ default:
+ break;
+ }
+ }
+ CuAssertStrEquals(tc, "option: a with foo\n", str);
+}
+
+static void optional_option_notgiven(CuTest *tc)
+{
+ int largc = 2;
+ const char * const largv[] = {"testprog", "-a"};
+ apr_getopt_t *opt;
+ apr_status_t rv;
+ char data;
+ const char *optarg;
+ char str[8196];
+
+ str[0] = '\0';
+ rv = apr_getopt_init(&opt, p, largc, largv);
+ CuAssertIntEquals(tc, APR_SUCCESS, rv);
+
+ opt->errfn = unknown_arg;
+ opt->errarg = str;
+
+ while (apr_getopt(opt, "a::", &data, &optarg) == APR_SUCCESS) {
+ switch (data) {
+ case 'a':
+ format_arg(str, data, optarg);
+ break;
+ default:
+ break;
+ }
+ }
+#if 0
+/* Our version of getopt doesn't allow for optional arguments. */
+ CuAssertStrEquals(tc, "option: a\n", str);
+#endif
+ CuAssertStrEquals(tc, "testprog: option requires an argument -- a\n", str);
+}
+
+CuSuite *testgetopt(void)
+{
+ CuSuite *suite = CuSuiteNew("Getopt");
- while (opt->ind < opt->argc)
- printf("extra arg: %s\n", opt->argv[opt->ind++]);
+ SUITE_ADD_TEST(suite, no_options);
+ SUITE_ADD_TEST(suite, no_options_found);
+ SUITE_ADD_TEST(suite, required_option);
+ SUITE_ADD_TEST(suite, required_option_notgiven);
+ SUITE_ADD_TEST(suite, optional_option);
+ SUITE_ADD_TEST(suite, optional_option_notgiven);
- return 0;
+ return suite;
}