tests/test_json.c

changeset 1081
33c9d7e7d830
parent 1080
e16f4f336e3c
child 1082
46cdc8689fc4
--- a/tests/test_json.c	Fri Jan 03 17:12:28 2025 +0100
+++ b/tests/test_json.c	Fri Jan 03 17:16:49 2025 +0100
@@ -713,52 +713,11 @@
     cx_testing_allocator_destroy(&talloc);
 }
 
-CX_TEST(test_json_write_default_format) {
-    CxTestingAllocator talloc;
-    cx_testing_allocator_init(&talloc);
-    CxAllocator *allocator = &talloc.base;
-    CX_TEST_DO {
-        // expected value
-        cxstring expected = CX_STR("{\"bool\":false,\"nested\":{\"floats\":[3.1415,47.11,8.15],\"ints\":[4,8,15,16,23,42],\"literals\":[true,null,false],\"string\":\"test\"},\"num\":47.11,\"strings\":[\"hello\",\"world\"]}");
 
-        // create the value
-        CxJsonValue *obj = cxJsonCreateObj(allocator);
-        cxJsonObjPutLiteral(obj, CX_STR("bool"), CX_JSON_FALSE);
-        cxJsonObjPutNumber(obj, CX_STR("num"), 47.11);
-        CxJsonValue *strings = cxJsonObjPutArr(obj, CX_STR("strings"));
-        cxJsonArrAddCxStrings(strings, (cxstring[]) {CX_STR("hello"), CX_STR("world")}, 2);
-        CxJsonValue *nested = cxJsonObjPutObj(obj, CX_STR("nested"));
-        cxJsonObjPutString(nested, CX_STR("string"), "test");
-        cxJsonArrAddNumbers(cxJsonObjPutArr(nested, CX_STR("floats")),
-            (double[]){3.1415, 47.11, 8.15}, 3);
-        cxJsonArrAddLiterals(cxJsonObjPutArr(nested, CX_STR("literals")),
-                    (CxJsonLiteral[]){CX_JSON_TRUE, CX_JSON_NULL, CX_JSON_FALSE}, 3);
-        cxJsonArrAddIntegers(cxJsonObjPutArr(nested, CX_STR("ints")),
-            (int64_t[]){4, 8, 15, 16, 23, 42}, 6);
-
-        // write it to a buffer
-        CxBuffer buf;
-        cxBufferInit(&buf, NULL, 256, NULL, CX_BUFFER_DEFAULT);
-        int result = cxJsonWrite(&buf, obj, (cx_write_func) cxBufferWrite, NULL);
-        cxBufferTerminate(&buf); // makes debugging easier
-        CX_TEST_ASSERT(result == 0);
-
-        // compare the string
-        CX_TEST_ASSERT(0 == cx_strcmp(cx_strn(buf.space, buf.size), expected));
-
-        // destroy everything
-        cxBufferDestroy(&buf);
-        cxJsonValueFree(obj);
-        CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
-    }
-    cx_testing_allocator_destroy(&talloc);
-}
-
-
-CX_TEST_SUBROUTINE(test_json_write_pretty_default_sub,
+CX_TEST_SUBROUTINE(test_json_write_sub,
         const CxAllocator *allocator,
         cxstring expected,
-        bool use_spaces
+        const CxJsonWriter *writer
 ) {
     // create the value
     CxJsonValue *obj = cxJsonCreateObj(allocator);
@@ -788,8 +747,7 @@
     // write it to a buffer
     CxBuffer buf;
     cxBufferInit(&buf, NULL, 512, NULL, CX_BUFFER_DEFAULT);
-    CxJsonWriter writer = cxJsonWriterPretty(use_spaces);
-    int result = cxJsonWrite(&buf, obj, (cx_write_func) cxBufferWrite, &writer);
+    int result = cxJsonWrite(&buf, obj, (cx_write_func) cxBufferWrite, writer);
     cxBufferTerminate(&buf); // makes debugging easier
     CX_TEST_ASSERT(result == 0);
 
@@ -801,12 +759,44 @@
     cxJsonValueFree(obj);
 }
 
+CX_TEST(test_json_write_default_format) {
+    CxTestingAllocator talloc;
+    cx_testing_allocator_init(&talloc);
+    CxAllocator *allocator = &talloc.base;
+    CX_TEST_DO {
+        // expected value
+        cxstring expected = CX_STR(
+"{\"bool\":false,"
+"\"int\":47,"
+"\"nested\":{"
+"\"floats\":[3.1415,47.11,8.15],"
+"\"ints\":[4,8,15,[16,23],42],"
+"\"literals\":[true,null,false],"
+"\"objects\":[{"
+"\"name1\":1,"
+"\"name2\":3"
+"},{"
+"\"name1\":3,"
+"\"name2\":7"
+"}]"
+"},"
+"\"strings\":[\"hello\",\"world\"]"
+"}"
+        );
+
+        CxJsonWriter writer = cxJsonWriterCompact();
+        CX_TEST_CALL_SUBROUTINE(test_json_write_sub, allocator, expected, &writer);
+        CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
+        CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
+    }
+    cx_testing_allocator_destroy(&talloc);
+}
+
 CX_TEST(test_json_write_pretty_default_spaces) {
     CxTestingAllocator talloc;
     cx_testing_allocator_init(&talloc);
     CxAllocator *allocator = &talloc.base;
     CX_TEST_DO {
-        // expected value
         cxstring expected = CX_STR(
 "{\n"
 "    \"bool\": false,\n"
@@ -827,7 +817,8 @@
 "}"
         );
 
-        CX_TEST_CALL_SUBROUTINE(test_json_write_pretty_default_sub, allocator, expected, true);
+        CxJsonWriter writer = cxJsonWriterPretty(true);
+        CX_TEST_CALL_SUBROUTINE(test_json_write_sub, allocator, expected, &writer);
         CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
         CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
     }
@@ -839,7 +830,6 @@
     cx_testing_allocator_init(&talloc);
     CxAllocator *allocator = &talloc.base;
     CX_TEST_DO {
-        // expected value
         cxstring expected = CX_STR(
 "{\n"
 "\t\"bool\": false,\n"
@@ -859,7 +849,8 @@
 "\t\"strings\": [\"hello\", \"world\"]\n"
 "}"
         );
-        CX_TEST_CALL_SUBROUTINE(test_json_write_pretty_default_sub, allocator, expected, false);
+        CxJsonWriter writer = cxJsonWriterPretty(false);
+        CX_TEST_CALL_SUBROUTINE(test_json_write_sub, allocator, expected, &writer);
         CX_TEST_ASSERT(cx_testing_allocator_verify(&talloc));
     }
     cx_testing_allocator_destroy(&talloc);

mercurial