mirror of
https://github.com/json-c/json-c.git
synced 2026-03-13 18:19:06 +08:00
Fix memory leak in test_safe_json_pointer_set, the caller must free the passed value when json_pointer_set failed. Also, reformat.
This commit is contained in:
@@ -166,6 +166,7 @@ static int test_cb_print_msg(json_object *parent, const char *key, size_t idx,
|
||||
json_object *value, void *priv)
|
||||
{
|
||||
printf("PASSED - SET_WITH_CB - This callback is called\n");
|
||||
json_object_put(value);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -177,20 +178,23 @@ static int test_cb_reject_logic(json_object *parent, const char *key, size_t idx
|
||||
if (key && strcmp(key, "reject") == 0)
|
||||
{
|
||||
printf("PASSED - SET_WITH_CB - Callback correctly identified key 'reject' to reject\n");
|
||||
// Note: caller of json_pointer_set must free value
|
||||
return -1;
|
||||
}
|
||||
json_object_put(value);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void test_set_with_cb(void)
|
||||
{
|
||||
struct json_object *jo1 = json_tokener_parse(input_json_str);
|
||||
struct json_object *jo2, *jo1 = json_tokener_parse(input_json_str);
|
||||
size_t limit_index = 5;
|
||||
|
||||
assert(jo1 != NULL);
|
||||
printf("PASSED - SET_WITH_CB - LOADED TEST JSON\n");
|
||||
printf("%s\n", json_object_get_string(jo1));
|
||||
|
||||
|
||||
assert(0 == json_pointer_set_with_cb(&jo1, "/foo/1", json_object_new_string("cod"), test_cb_print_msg, 1, NULL));
|
||||
printf("PASSED - SET_WITH_CB - callback test_cb_print_msg for /foo/1\n");
|
||||
|
||||
@@ -200,11 +204,13 @@ static void test_set_with_cb(void)
|
||||
assert(0 == json_pointer_set_with_cb(&jo1, "/foo/5", json_object_new_string("border"), json_object_array_put_with_idx_limit_cb, 0, &limit_index));
|
||||
printf("PASSED - SET_WITH_CB - failed with callback json_object_array_put_with_idx_limit_cb for /foo/5 with limit_index 5\n");
|
||||
|
||||
assert(0 != json_pointer_set_with_cb(&jo1, "/foo/10", json_object_new_string("out"), json_object_array_put_with_idx_limit_cb, 0, &limit_index));
|
||||
assert(0 != json_pointer_set_with_cb(&jo1, "/foo/10", (jo2 = json_object_new_string("out")), json_object_array_put_with_idx_limit_cb, 0, &limit_index));
|
||||
json_object_put(jo2);
|
||||
assert(errno == EINVAL);
|
||||
printf("PASSED - SET_WITH_CB - failed with callback json_object_array_put_with_idx_limit_cb for /foo/10 with limit_index 5\n");
|
||||
|
||||
assert(0 != json_pointer_set_with_cb(&jo1, "/foo/2", json_object_new_string("null_priv"), json_object_array_put_with_idx_limit_cb, 0, NULL));
|
||||
assert(0 != json_pointer_set_with_cb(&jo1, "/foo/2", (jo2 = json_object_new_string("null_priv")), json_object_array_put_with_idx_limit_cb, 0, NULL));
|
||||
json_object_put(jo2);
|
||||
assert(errno == EFAULT);
|
||||
printf("PASSED - SET_WITH_CB - failed with callback json_object_array_put_with_idx_limit_cb with NULL priv\n");
|
||||
|
||||
@@ -227,7 +233,8 @@ static void test_set_with_cb(void)
|
||||
assert(0 == json_pointer_set_with_cb(&jo1, "/data/accept", json_object_new_string("accepted_value"), test_cb_reject_logic, 1, NULL));
|
||||
printf("PASSED - SET_WITH_CB - Rejection callback approved an allowed key\n");
|
||||
|
||||
assert(0 != json_pointer_set_with_cb(&jo1, "/data/reject", json_object_new_string("rejected_value"), test_cb_reject_logic, 1, NULL));
|
||||
assert(0 != json_pointer_set_with_cb(&jo1, "/data/reject", (jo2 = json_object_new_string("rejected_value")), test_cb_reject_logic, 1, NULL));
|
||||
json_object_put(jo2);
|
||||
printf("PASSED - SET_WITH_CB - Rejection callback rejected a forbidden key\n");
|
||||
|
||||
json_object_put(jo1);
|
||||
|
||||
Reference in New Issue
Block a user