The test_valid_kvargs() function is too long to understand, extract the with keys tests as one stand-alone testcase.
Signed-off-by: Chengwen Feng <fengcheng...@huawei.com> Acked-by: Stephen Hemminger <step...@networkplumber.org> --- app/test/test_kvargs.c | 60 +++++++++++++++++++++++++----------------- 1 file changed, 36 insertions(+), 24 deletions(-) diff --git a/app/test/test_kvargs.c b/app/test/test_kvargs.c index 2147080160..8b53d6d585 100644 --- a/app/test/test_kvargs.c +++ b/app/test/test_kvargs.c @@ -43,30 +43,6 @@ static int test_valid_kvargs(void) const char *valid_keys_list[] = { "foo", "check", NULL }; const char **valid_keys; - /* second test using valid_keys */ - args = "foo=droids,check=value0,check=value1,check=wrong_value"; - valid_keys = valid_keys_list; - kvlist = rte_kvargs_parse(args, valid_keys); - if (kvlist == NULL) { - printf("rte_kvargs_parse() error"); - goto fail; - } - /* call check_handler() on all entries with key="check", it - * should fail as the value is not recognized by the handler */ - if (rte_kvargs_process(kvlist, "check", check_handler, NULL) == 0) { - printf("rte_kvargs_process() is success but should not\n"); - rte_kvargs_free(kvlist); - goto fail; - } - count = rte_kvargs_count(kvlist, "check"); - if (count != 3) { - printf("invalid count value %d after rte_kvargs_count(check)\n", - count); - rte_kvargs_free(kvlist); - goto fail; - } - rte_kvargs_free(kvlist); - /* third test using list as value */ args = "foo=[0,1],check=value2"; valid_keys = valid_keys_list; @@ -224,6 +200,41 @@ test_parse_without_valid_keys(void) return 0; } +static int +test_parse_with_valid_keys(void) +{ + const char *args = "foo=droids,check=value0,check=value1,check=wrong_value"; + const char *valid_keys[] = { "foo", "check", NULL }; + struct rte_kvargs *kvlist; + + kvlist = rte_kvargs_parse(args, valid_keys); + if (kvlist == NULL) { + printf("rte_kvargs_parse() error\n"); + return -1; + } + + /* call check_handler() on all entries with key="check", it + * should fail as the value is not recognized by the handler + */ + count = 0; + if (rte_kvargs_process(kvlist, "check", check_handler, NULL) == 0 || count != 2) { + printf("rte_kvargs_process(check) is success but should not\n"); + rte_kvargs_free(kvlist); + return -1; + } + + count = rte_kvargs_count(kvlist, "check"); + if (count != 3) { + printf("invalid count value %u after rte_kvargs_count(check)\n", + count); + rte_kvargs_free(kvlist); + return -1; + } + + rte_kvargs_free(kvlist); + return 0; +} + /* test several error cases */ static int test_invalid_kvargs(void) { @@ -267,6 +278,7 @@ static struct unit_test_suite kvargs_test_suite = { TEST_CASE(test_valid_kvargs), TEST_CASE(test_basic_token_count), TEST_CASE(test_parse_without_valid_keys), + TEST_CASE(test_parse_with_valid_keys), TEST_CASE(test_invalid_kvargs), TEST_CASES_END() /**< NULL terminate unit test array */ } -- 2.17.1