Commit f20e4f23 authored by Rusty Russell's avatar Rusty Russell

opt: remove unused debug function and code, test a few more corner cases.

parent b2d126ee
......@@ -41,8 +41,6 @@ static const char *first_opt(unsigned *i, unsigned *len)
static const char *next_opt(const char *p, unsigned *i, unsigned *len)
{
if (!p)
(*i)++;
for (; *i < opt_count; (*i)++) {
if (opt_table[*i].flags == OPT_SUBTABLE)
continue;
......@@ -259,13 +257,6 @@ static void parse_fail(void (*errlog)(const char *fmt, ...),
strcspn(longopt, "/"), longopt, problem);
}
void dump_optstate(void);
void dump_optstate(void)
{
printf("opterr = %i, optind = %i, optopt = %i, optarg = %s\n",
opterr, optind, optopt, optarg);
}
/* Parse your arguments. */
bool opt_parse(int *argc, char *argv[], void (*errlog)(const char *fmt, ...))
{
......
......@@ -3,6 +3,7 @@
#include <ccan/tap/tap.h>
#include <setjmp.h>
#include <stdlib.h>
#include <limits.h>
#include "utils.h"
/* We don't actually want it to exit... */
......@@ -48,7 +49,7 @@ static int saved_printf(const char *fmt, ...)
/* Test helpers. */
int main(int argc, char *argv[])
{
plan_tests(88);
plan_tests(96);
/* opt_set_bool */
{
......@@ -66,6 +67,9 @@ int main(int argc, char *argv[])
ok1(!arg);
ok1(parse_args(&argc, &argv, "-b", "true", NULL));
ok1(arg);
ok1(!parse_args(&argc, &argv, "-b", "unknown", NULL));
ok1(arg);
ok1(strstr(err_output, ": -b: Invalid argument 'unknown'"));
}
/* opt_set_invbool */
{
......@@ -84,6 +88,9 @@ int main(int argc, char *argv[])
ok1(arg);
ok1(parse_args(&argc, &argv, "-b", "true", NULL));
ok1(!arg);
ok1(!parse_args(&argc, &argv, "-b", "unknown", NULL));
ok1(!arg);
ok1(strstr(err_output, ": -b: Invalid argument 'unknown'"));
}
/* opt_set_charp */
{
......@@ -122,6 +129,17 @@ int main(int argc, char *argv[])
ok1(arg == 0);
ok1(!parse_args(&argc, &argv, "-a", "100crap", NULL));
ok1(!parse_args(&argc, &argv, "-a", "4294967296", NULL));
if (ULONG_MAX == UINT_MAX) {
pass("Can't test overflow");
pass("Can't test error message");
} else {
char buf[30];
sprintf(buf, "%lu", ULONG_MAX);
ok1(!parse_args(&argc, &argv, "-a", buf, NULL));
ok1(strstr(err_output, ": -a: value '")
&& strstr(err_output, buf)
&& strstr(err_output, "' does not fit into an integer"));
}
}
/* opt_set_longval */
{
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment