mirror of
https://github.com/DaveGamble/cJSON
synced 2025-01-27 09:43:42 +00:00
tests: Ensure that failed parsing returns invalid items
This commit is contained in:
parent
c6e1a281f9
commit
5986edba1d
@ -27,6 +27,7 @@
|
|||||||
|
|
||||||
extern void reset(cJSON *item);
|
extern void reset(cJSON *item);
|
||||||
extern char *read_file(const char *filename);
|
extern char *read_file(const char *filename);
|
||||||
|
extern cjbool assert_is_invalid(cJSON *item);
|
||||||
|
|
||||||
/* assertion helper macros */
|
/* assertion helper macros */
|
||||||
#define assert_has_type(item, item_type) TEST_ASSERT_BITS_MESSAGE(0xFF, item_type, item->type, "Item doesn't have expected type.")
|
#define assert_has_type(item, item_type) TEST_ASSERT_BITS_MESSAGE(0xFF, item_type, item->type, "Item doesn't have expected type.")
|
||||||
@ -41,5 +42,11 @@ extern char *read_file(const char *filename);
|
|||||||
TEST_ASSERT_NULL_MESSAGE(item->prev, "Linked list previous pointer is not NULL.")
|
TEST_ASSERT_NULL_MESSAGE(item->prev, "Linked list previous pointer is not NULL.")
|
||||||
#define assert_has_child(item) TEST_ASSERT_NOT_NULL_MESSAGE(item->child, "Item doesn't have a child.")
|
#define assert_has_child(item) TEST_ASSERT_NOT_NULL_MESSAGE(item->child, "Item doesn't have a child.")
|
||||||
#define assert_has_no_child(item) TEST_ASSERT_NULL_MESSAGE(item->child, "Item has a child.")
|
#define assert_has_no_child(item) TEST_ASSERT_NULL_MESSAGE(item->child, "Item has a child.")
|
||||||
|
#define assert_is_invalid(item) \
|
||||||
|
assert_has_type(item, cJSON_Invalid);\
|
||||||
|
assert_not_in_list(item);\
|
||||||
|
assert_has_no_child(item);\
|
||||||
|
assert_has_no_string(item);\
|
||||||
|
assert_has_no_valuestring(item)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -47,6 +47,7 @@ static void assert_is_array(cJSON *array_item)
|
|||||||
static void assert_not_array(const char *json)
|
static void assert_not_array(const char *json)
|
||||||
{
|
{
|
||||||
TEST_ASSERT_NULL(parse_array(item, (const unsigned char*)json, &error_pointer));
|
TEST_ASSERT_NULL(parse_array(item, (const unsigned char*)json, &error_pointer));
|
||||||
|
assert_is_invalid(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void assert_parse_array(const char *json)
|
static void assert_parse_array(const char *json)
|
||||||
|
@ -55,6 +55,8 @@ static void assert_is_child(cJSON *child_item, const char *name, int type)
|
|||||||
static void assert_not_object(const char *json)
|
static void assert_not_object(const char *json)
|
||||||
{
|
{
|
||||||
TEST_ASSERT_NULL(parse_object(item, (const unsigned char*)json, &error_pointer));
|
TEST_ASSERT_NULL(parse_object(item, (const unsigned char*)json, &error_pointer));
|
||||||
|
assert_is_invalid(item);
|
||||||
|
reset(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void assert_parse_object(const char *json)
|
static void assert_parse_object(const char *json)
|
||||||
@ -66,9 +68,12 @@ static void assert_parse_object(const char *json)
|
|||||||
static void parse_object_should_parse_empty_objects(void)
|
static void parse_object_should_parse_empty_objects(void)
|
||||||
{
|
{
|
||||||
assert_parse_object("{}");
|
assert_parse_object("{}");
|
||||||
TEST_ASSERT_NULL(item->child);
|
assert_has_no_child(item);
|
||||||
|
reset(item);
|
||||||
|
|
||||||
assert_parse_object("{\n\t}");
|
assert_parse_object("{\n\t}");
|
||||||
TEST_ASSERT_NULL(item->child);
|
assert_has_no_child(item);
|
||||||
|
reset(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void parse_array_should_parse_arrays_with_one_element(void)
|
static void parse_array_should_parse_arrays_with_one_element(void)
|
||||||
|
@ -54,7 +54,11 @@ static void assert_parse_string(const char *string, const char *expected)
|
|||||||
item->valuestring = NULL;
|
item->valuestring = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define assert_not_parse_string(string) TEST_ASSERT_NULL_MESSAGE(parse_string(item, (const unsigned char*)string, &error_pointer), "Malformed string should not be accepted")
|
#define assert_not_parse_string(string) \
|
||||||
|
TEST_ASSERT_NULL_MESSAGE(parse_string(item, (const unsigned char*)string, &error_pointer), "Malformed string should not be accepted");\
|
||||||
|
assert_is_invalid(item)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static void parse_string_should_parse_strings(void)
|
static void parse_string_should_parse_strings(void)
|
||||||
{
|
{
|
||||||
@ -65,35 +69,44 @@ static void parse_string_should_parse_strings(void)
|
|||||||
assert_parse_string(
|
assert_parse_string(
|
||||||
"\"\\\"\\\\\\/\\b\\f\\n\\r\\t\\u20AC\\u732b\"",
|
"\"\\\"\\\\\\/\\b\\f\\n\\r\\t\\u20AC\\u732b\"",
|
||||||
"\"\\/\b\f\n\r\t€猫");
|
"\"\\/\b\f\n\r\t€猫");
|
||||||
|
reset(item);
|
||||||
assert_parse_string("\"\b\f\n\r\t\"", "\b\f\n\r\t");
|
assert_parse_string("\"\b\f\n\r\t\"", "\b\f\n\r\t");
|
||||||
|
reset(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void parse_string_should_parse_utf16_surrogate_pairs(void)
|
static void parse_string_should_parse_utf16_surrogate_pairs(void)
|
||||||
{
|
{
|
||||||
assert_parse_string("\"\\uD83D\\udc31\"", "🐱");
|
assert_parse_string("\"\\uD83D\\udc31\"", "🐱");
|
||||||
|
reset(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void parse_string_should_not_parse_non_strings(void)
|
static void parse_string_should_not_parse_non_strings(void)
|
||||||
{
|
{
|
||||||
assert_not_parse_string("this\" is not a string\"");
|
assert_not_parse_string("this\" is not a string\"");
|
||||||
|
reset(item);
|
||||||
assert_not_parse_string("");
|
assert_not_parse_string("");
|
||||||
|
reset(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void parse_string_should_not_parse_invalid_backslash(void)
|
static void parse_string_should_not_parse_invalid_backslash(void)
|
||||||
{
|
{
|
||||||
assert_not_parse_string("Abcdef\\123");
|
assert_not_parse_string("Abcdef\\123");
|
||||||
|
reset(item);
|
||||||
assert_not_parse_string("Abcdef\\e23");
|
assert_not_parse_string("Abcdef\\e23");
|
||||||
|
reset(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void parse_string_should_not_overflow_with_closing_backslash(void)
|
static void parse_string_should_not_overflow_with_closing_backslash(void)
|
||||||
{
|
{
|
||||||
assert_not_parse_string("\"000000000000000000\\");
|
assert_not_parse_string("\"000000000000000000\\");
|
||||||
|
reset(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void parse_string_should_parse_bug_94(void)
|
static void parse_string_should_parse_bug_94(void)
|
||||||
{
|
{
|
||||||
const char string[] = "\"~!@\\\\#$%^&*()\\\\\\\\-\\\\+{}[]:\\\\;\\\\\\\"\\\\<\\\\>?/.,DC=ad,DC=com\"";
|
const char string[] = "\"~!@\\\\#$%^&*()\\\\\\\\-\\\\+{}[]:\\\\;\\\\\\\"\\\\<\\\\>?/.,DC=ad,DC=com\"";
|
||||||
assert_parse_string(string, "~!@\\#$%^&*()\\\\-\\+{}[]:\\;\\\"\\<\\>?/.,DC=ad,DC=com");
|
assert_parse_string(string, "~!@\\#$%^&*()\\\\-\\+{}[]:\\;\\\"\\<\\>?/.,DC=ad,DC=com");
|
||||||
|
reset(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
|
Loading…
Reference in New Issue
Block a user