upstream: test argv_split() optional termination on comments

OpenBSD-Regress-ID: 9fd1c4a27a409897437c010cfd79c54b639a059c
This commit is contained in:
djm@openbsd.org 2021-06-08 07:40:12 +00:00 committed by Damien Miller
parent a023138957
commit 78e30af3e2
1 changed files with 69 additions and 29 deletions

View File

@ -1,4 +1,4 @@
/* $OpenBSD: test_argv.c,v 1.2 2021/05/21 04:03:47 djm Exp $ */ /* $OpenBSD: test_argv.c,v 1.3 2021/06/08 07:40:12 djm Exp $ */
/* /*
* Regress test for misc argv handling functions. * Regress test for misc argv handling functions.
* *
@ -21,16 +21,6 @@
void test_argv(void); void test_argv(void);
static void
free_argv(char **av, int ac)
{
int i;
for (i = 0; i < ac; i++)
free(av[i]);
free(av);
}
void void
test_argv(void) test_argv(void)
{ {
@ -39,19 +29,18 @@ test_argv(void)
#define RESET_ARGV() \ #define RESET_ARGV() \
do { \ do { \
free_argv(av, ac); \ argv_free(av, ac); \
av = NULL; \ av = NULL; \
ac = -1; \ ac = -1; \
} while (0) } while (0)
TEST_START("empty args"); TEST_START("empty args");
RESET_ARGV(); ASSERT_INT_EQ(argv_split("", &ac, &av, 0), 0);
ASSERT_INT_EQ(argv_split("", &ac, &av), 0);
ASSERT_INT_EQ(ac, 0); ASSERT_INT_EQ(ac, 0);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_PTR_EQ(av[0], NULL); ASSERT_PTR_EQ(av[0], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split(" ", &ac, &av), 0); ASSERT_INT_EQ(argv_split(" ", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 0); ASSERT_INT_EQ(ac, 0);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_PTR_EQ(av[0], NULL); ASSERT_PTR_EQ(av[0], NULL);
@ -59,14 +48,13 @@ test_argv(void)
TEST_DONE(); TEST_DONE();
TEST_START("trivial args"); TEST_START("trivial args");
RESET_ARGV(); ASSERT_INT_EQ(argv_split("leamas", &ac, &av, 0), 0);
ASSERT_INT_EQ(argv_split("leamas", &ac, &av), 0);
ASSERT_INT_EQ(ac, 1); ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "leamas"); ASSERT_STRING_EQ(av[0], "leamas");
ASSERT_PTR_EQ(av[1], NULL); ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split("smiley leamas", &ac, &av), 0); ASSERT_INT_EQ(argv_split("smiley leamas", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 2); ASSERT_INT_EQ(ac, 2);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "smiley"); ASSERT_STRING_EQ(av[0], "smiley");
@ -76,27 +64,26 @@ test_argv(void)
TEST_DONE(); TEST_DONE();
TEST_START("quoted"); TEST_START("quoted");
RESET_ARGV(); ASSERT_INT_EQ(argv_split("\"smiley\"", &ac, &av, 0), 0);
ASSERT_INT_EQ(argv_split("\"smiley\"", &ac, &av), 0);
ASSERT_INT_EQ(ac, 1); ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "smiley"); ASSERT_STRING_EQ(av[0], "smiley");
ASSERT_PTR_EQ(av[1], NULL); ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split("leamas \" smiley \"", &ac, &av), 0); ASSERT_INT_EQ(argv_split("leamas \" smiley \"", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 2); ASSERT_INT_EQ(ac, 2);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "leamas"); ASSERT_STRING_EQ(av[0], "leamas");
ASSERT_STRING_EQ(av[1], " smiley "); ASSERT_STRING_EQ(av[1], " smiley ");
ASSERT_PTR_EQ(av[2], NULL); ASSERT_PTR_EQ(av[2], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split("\"smiley leamas\"", &ac, &av), 0); ASSERT_INT_EQ(argv_split("\"smiley leamas\"", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 1); ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "smiley leamas"); ASSERT_STRING_EQ(av[0], "smiley leamas");
ASSERT_PTR_EQ(av[1], NULL); ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split("smiley\" leamas\" liz", &ac, &av), 0); ASSERT_INT_EQ(argv_split("smiley\" leamas\" liz", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 2); ASSERT_INT_EQ(ac, 2);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "smiley leamas"); ASSERT_STRING_EQ(av[0], "smiley leamas");
@ -106,39 +93,92 @@ test_argv(void)
TEST_DONE(); TEST_DONE();
TEST_START("escaped"); TEST_START("escaped");
RESET_ARGV(); ASSERT_INT_EQ(argv_split("\\\"smiley\\'", &ac, &av, 0), 0);
ASSERT_INT_EQ(argv_split("\\\"smiley\\'", &ac, &av), 0);
ASSERT_INT_EQ(ac, 1); ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "\"smiley'"); ASSERT_STRING_EQ(av[0], "\"smiley'");
ASSERT_PTR_EQ(av[1], NULL); ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split("'\\'smiley\\\"'", &ac, &av), 0); ASSERT_INT_EQ(argv_split("'\\'smiley\\\"'", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 1); ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "'smiley\""); ASSERT_STRING_EQ(av[0], "'smiley\"");
ASSERT_PTR_EQ(av[1], NULL); ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split("smiley\\'s leamas\\'", &ac, &av), 0); ASSERT_INT_EQ(argv_split("smiley\\'s leamas\\'", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 2); ASSERT_INT_EQ(ac, 2);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "smiley's"); ASSERT_STRING_EQ(av[0], "smiley's");
ASSERT_STRING_EQ(av[1], "leamas'"); ASSERT_STRING_EQ(av[1], "leamas'");
ASSERT_PTR_EQ(av[2], NULL); ASSERT_PTR_EQ(av[2], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split("leamas\\\\smiley", &ac, &av), 0); ASSERT_INT_EQ(argv_split("leamas\\\\smiley", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 1); ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "leamas\\smiley"); ASSERT_STRING_EQ(av[0], "leamas\\smiley");
ASSERT_PTR_EQ(av[1], NULL); ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split("leamas\\\\ \\\\smiley", &ac, &av), 0); ASSERT_INT_EQ(argv_split("leamas\\\\ \\\\smiley", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 2); ASSERT_INT_EQ(ac, 2);
ASSERT_PTR_NE(av, NULL); ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "leamas\\"); ASSERT_STRING_EQ(av[0], "leamas\\");
ASSERT_STRING_EQ(av[1], "\\smiley"); ASSERT_STRING_EQ(av[1], "\\smiley");
ASSERT_PTR_EQ(av[2], NULL); ASSERT_PTR_EQ(av[2], NULL);
RESET_ARGV(); RESET_ARGV();
ASSERT_INT_EQ(argv_split("smiley\\ leamas", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "smiley leamas");
ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV();
TEST_DONE();
TEST_START("quoted escaped");
ASSERT_INT_EQ(argv_split("'smiley\\ leamas'", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "smiley\\ leamas");
ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV();
ASSERT_INT_EQ(argv_split("\"smiley\\ leamas\"", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "smiley\\ leamas");
ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV();
TEST_DONE();
TEST_START("comments");
ASSERT_INT_EQ(argv_split("# gold", &ac, &av, 0), 0);
ASSERT_INT_EQ(ac, 2);
ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "#");
ASSERT_STRING_EQ(av[1], "gold");
ASSERT_PTR_EQ(av[2], NULL);
RESET_ARGV();
ASSERT_INT_EQ(argv_split("# gold", &ac, &av, 1), 0);
ASSERT_INT_EQ(ac, 0);
ASSERT_PTR_NE(av, NULL);
ASSERT_PTR_EQ(av[0], NULL);
RESET_ARGV();
ASSERT_INT_EQ(argv_split("leamas#gold", &ac, &av, 1), 0);
ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "leamas#gold");
ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV();
ASSERT_INT_EQ(argv_split("\"leamas # gold\"", &ac, &av, 1), 0);
ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "leamas # gold");
ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV();
ASSERT_INT_EQ(argv_split("\"leamas\"#gold", &ac, &av, 1), 0);
ASSERT_INT_EQ(ac, 1);
ASSERT_PTR_NE(av, NULL);
ASSERT_STRING_EQ(av[0], "leamas#gold");
ASSERT_PTR_EQ(av[1], NULL);
RESET_ARGV();
TEST_DONE(); TEST_DONE();
/* XXX test char *argv_assemble(int argc, char **argv) */ /* XXX test char *argv_assemble(int argc, char **argv) */