diff options
Diffstat (limited to 'lib/tests/test_opts1.c')
| -rw-r--r-- | lib/tests/test_opts1.c | 51 |
1 files changed, 31 insertions, 20 deletions
diff --git a/lib/tests/test_opts1.c b/lib/tests/test_opts1.c index 984183d3..fa95c4d4 100644 --- a/lib/tests/test_opts1.c +++ b/lib/tests/test_opts1.c | |||
| @@ -40,37 +40,40 @@ void my_free(int *argc, char **newargv, char **argv) { | |||
| 40 | #else | 40 | #else |
| 41 | void my_free(int *argc, char **newargv, char **argv) { | 41 | void my_free(int *argc, char **newargv, char **argv) { |
| 42 | /* Free stuff (and print while we're at it) */ | 42 | /* Free stuff (and print while we're at it) */ |
| 43 | int i, freeflag = 1; | 43 | bool freeflag = true; |
| 44 | printf(" Arg(%i): ", *argc + 1); | 44 | printf(" Arg(%i): ", *argc + 1); |
| 45 | printf("'%s' ", newargv[0]); | 45 | printf("'%s' ", newargv[0]); |
| 46 | for (i = 1; i < *argc; i++) { | 46 | |
| 47 | for (int i = 1; i < *argc; i++) { | ||
| 47 | printf("'%s' ", newargv[i]); | 48 | printf("'%s' ", newargv[i]); |
| 48 | /* Stop freeing when we get to the start of the original array */ | 49 | /* Stop freeing when we get to the start of the original array */ |
| 49 | if (freeflag) { | 50 | if (freeflag) { |
| 50 | if (newargv[i] == argv[1]) | 51 | if (newargv[i] == argv[1]) { |
| 51 | freeflag = 0; | 52 | freeflag = false; |
| 52 | else | 53 | } else { |
| 53 | free(newargv[i]); | 54 | free(newargv[i]); |
| 55 | } | ||
| 54 | } | 56 | } |
| 55 | } | 57 | } |
| 56 | printf("\n"); | 58 | printf("\n"); |
| 57 | /* Free only if it's a different array */ | 59 | /* Free only if it's a different array */ |
| 58 | if (newargv != argv) | 60 | if (newargv != argv) { |
| 59 | free(newargv); | 61 | free(newargv); |
| 62 | } | ||
| 60 | *argc = 0; | 63 | *argc = 0; |
| 61 | } | 64 | } |
| 62 | #endif | 65 | #endif |
| 63 | 66 | ||
| 64 | int array_diff(int i1, char **a1, int i2, char **a2) { | 67 | int array_diff(int i1, char **a1, int i2, char **a2) { |
| 65 | int i; | ||
| 66 | |||
| 67 | if (i1 != i2) { | 68 | if (i1 != i2) { |
| 68 | printf(" Argument count doesn't match!\n"); | 69 | printf(" Argument count doesn't match!\n"); |
| 69 | return 0; | 70 | return 0; |
| 70 | } | 71 | } |
| 71 | for (i = 0; i <= i1; i++) { | 72 | |
| 72 | if (a1[i] == NULL && a2[i] == NULL) | 73 | for (int i = 0; i <= i1; i++) { |
| 74 | if (a1[i] == NULL && a2[i] == NULL) { | ||
| 73 | continue; | 75 | continue; |
| 76 | } | ||
| 74 | if (a1[i] == NULL || a2[i] == NULL) { | 77 | if (a1[i] == NULL || a2[i] == NULL) { |
| 75 | printf(" Argument # %i null in one array!\n", i); | 78 | printf(" Argument # %i null in one array!\n", i); |
| 76 | return 0; | 79 | return 0; |
| @@ -84,11 +87,10 @@ int array_diff(int i1, char **a1, int i2, char **a2) { | |||
| 84 | } | 87 | } |
| 85 | 88 | ||
| 86 | int main(int argc, char **argv) { | 89 | int main(int argc, char **argv) { |
| 87 | char **argv_new = NULL; | ||
| 88 | int i, argc_test; | ||
| 89 | |||
| 90 | plan_tests(5); | 90 | plan_tests(5); |
| 91 | 91 | ||
| 92 | char **argv_new = NULL; | ||
| 93 | int argc_test; | ||
| 92 | { | 94 | { |
| 93 | char *argv_test[] = {"prog_name", (char *)NULL}; | 95 | char *argv_test[] = {"prog_name", (char *)NULL}; |
| 94 | argc_test = 1; | 96 | argc_test = 1; |
| @@ -110,27 +112,36 @@ int main(int argc, char **argv) { | |||
| 110 | { | 112 | { |
| 111 | char *argv_test[] = {"prog_name", "--extra-opts=@./config-opts.ini", (char *)NULL}; | 113 | char *argv_test[] = {"prog_name", "--extra-opts=@./config-opts.ini", (char *)NULL}; |
| 112 | argc_test = 2; | 114 | argc_test = 2; |
| 113 | char *argv_known[] = {"prog_name", "--foo=Bar", "--this=Your Mother!", "--blank", (char *)NULL}; | 115 | char *argv_known[] = {"prog_name", "--foo=Bar", "--this=Your Mother!", "--blank", |
| 116 | (char *)NULL}; | ||
| 114 | argv_new = np_extra_opts(&argc_test, argv_test, "check_disk"); | 117 | argv_new = np_extra_opts(&argc_test, argv_test, "check_disk"); |
| 115 | ok(array_diff(argc_test, argv_new, 4, argv_known), "Only extra opts using default section"); | 118 | ok(array_diff(argc_test, argv_new, 4, argv_known), "Only extra opts using default section"); |
| 116 | my_free(&argc_test, argv_new, argv_test); | 119 | my_free(&argc_test, argv_new, argv_test); |
| 117 | } | 120 | } |
| 118 | 121 | ||
| 119 | { | 122 | { |
| 120 | char *argv_test[] = {"prog_name", "--extra-opts=sect1@./config-opts.ini", "--extra-opts", "sect2@./config-opts.ini", (char *)NULL}; | 123 | char *argv_test[] = {"prog_name", "--extra-opts=sect1@./config-opts.ini", "--extra-opts", |
| 124 | "sect2@./config-opts.ini", (char *)NULL}; | ||
| 121 | argc_test = 4; | 125 | argc_test = 4; |
| 122 | char *argv_known[] = {"prog_name", "--one=two", "--something else=oops", "--this=that", (char *)NULL}; | 126 | char *argv_known[] = {"prog_name", "--one=two", "--something else=oops", "--this=that", |
| 127 | (char *)NULL}; | ||
| 123 | argv_new = np_extra_opts(&argc_test, argv_test, "check_disk"); | 128 | argv_new = np_extra_opts(&argc_test, argv_test, "check_disk"); |
| 124 | ok(array_diff(argc_test, argv_new, 4, argv_known), "Only extra opts specified twice"); | 129 | ok(array_diff(argc_test, argv_new, 4, argv_known), "Only extra opts specified twice"); |
| 125 | my_free(&argc_test, argv_new, argv_test); | 130 | my_free(&argc_test, argv_new, argv_test); |
| 126 | } | 131 | } |
| 127 | 132 | ||
| 128 | { | 133 | { |
| 129 | char *argv_test[] = {"prog_name", "--arg1=val1", "--extra-opts=@./config-opts.ini", "--extra-opts", "sect1@./config-opts.ini", | 134 | char *argv_test[] = {"prog_name", |
| 130 | "--arg2", (char *)NULL}; | 135 | "--arg1=val1", |
| 136 | "--extra-opts=@./config-opts.ini", | ||
| 137 | "--extra-opts", | ||
| 138 | "sect1@./config-opts.ini", | ||
| 139 | "--arg2", | ||
| 140 | (char *)NULL}; | ||
| 131 | argc_test = 6; | 141 | argc_test = 6; |
| 132 | char *argv_known[] = {"prog_name", "--foo=Bar", "--this=Your Mother!", "--blank", "--one=two", | 142 | char *argv_known[] = {"prog_name", "--foo=Bar", "--this=Your Mother!", |
| 133 | "--arg1=val1", "--arg2", (char *)NULL}; | 143 | "--blank", "--one=two", "--arg1=val1", |
| 144 | "--arg2", (char *)NULL}; | ||
| 134 | argv_new = np_extra_opts(&argc_test, argv_test, "check_disk"); | 145 | argv_new = np_extra_opts(&argc_test, argv_test, "check_disk"); |
| 135 | ok(array_diff(argc_test, argv_new, 7, argv_known), "twice extra opts using two sections"); | 146 | ok(array_diff(argc_test, argv_new, 7, argv_known), "twice extra opts using two sections"); |
| 136 | my_free(&argc_test, argv_new, argv_test); | 147 | my_free(&argc_test, argv_new, argv_test); |
