testEdgeContainerInsertDelete.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. #include "testBase.h"
  2. static void testEdgeContainerOpsInsertBeyondSizeArray(void)
  3. {
  4. // 复杂链路:
  5. // Parse(Array) -> Insert(超范围) -> Compare。
  6. // 目标:验证超范围插入等价尾插。
  7. RyanJson_t arr = RyanJsonParse("[1,2]");
  8. TEST_ASSERT_NOT_NULL(arr);
  9. TEST_ASSERT_TRUE(RyanJsonInsert(arr, 99, RyanJsonCreateInt(NULL, 3)));
  10. RyanJson_t expect = RyanJsonParse("[1,2,3]");
  11. TEST_ASSERT_NOT_NULL(expect);
  12. TEST_ASSERT_TRUE(RyanJsonCompare(arr, expect));
  13. RyanJsonDelete(expect);
  14. RyanJsonDelete(arr);
  15. }
  16. static void testEdgeContainerOpsInsertBeyondSizeObject(void)
  17. {
  18. // 复杂链路:
  19. // Parse(Object) -> Insert(超范围) -> 顺序校验。
  20. // 目标:验证超范围插入等价尾插。
  21. RyanJson_t obj = RyanJsonParse("{\"a\":1}");
  22. TEST_ASSERT_NOT_NULL(obj);
  23. TEST_ASSERT_TRUE(RyanJsonInsert(obj, 99, RyanJsonCreateInt("b", 2)));
  24. TEST_ASSERT_EQUAL_STRING("a", RyanJsonGetKey(RyanJsonGetObjectByIndex(obj, 0)));
  25. TEST_ASSERT_EQUAL_STRING("b", RyanJsonGetKey(RyanJsonGetObjectByIndex(obj, 1)));
  26. RyanJsonDelete(obj);
  27. }
  28. static void testEdgeContainerOpsInsertAtHeadObject(void)
  29. {
  30. // 复杂链路:
  31. // Parse(Object) -> Insert(head) -> 顺序校验。
  32. // 目标:验证头插对顺序的影响。
  33. RyanJson_t obj = RyanJsonParse("{\"a\":1}");
  34. TEST_ASSERT_NOT_NULL(obj);
  35. TEST_ASSERT_TRUE(RyanJsonInsert(obj, 0, RyanJsonCreateInt("b", 2)));
  36. TEST_ASSERT_EQUAL_STRING("b", RyanJsonGetKey(RyanJsonGetObjectByIndex(obj, 0)));
  37. TEST_ASSERT_EQUAL_STRING("a", RyanJsonGetKey(RyanJsonGetObjectByIndex(obj, 1)));
  38. RyanJsonDelete(obj);
  39. }
  40. static void testEdgeContainerOpsInsertReorderObject(void)
  41. {
  42. // 复杂链路:
  43. // Create(Object) -> 多次 Insert(中间) -> 顺序校验。
  44. // 目标:验证中间插入的顺序效果。
  45. RyanJson_t obj = RyanJsonCreateObject();
  46. TEST_ASSERT_NOT_NULL(obj);
  47. TEST_ASSERT_TRUE(RyanJsonInsert(obj, 0, RyanJsonCreateInt("a", 1)));
  48. TEST_ASSERT_TRUE(RyanJsonInsert(obj, 1, RyanJsonCreateInt("b", 2)));
  49. TEST_ASSERT_TRUE(RyanJsonInsert(obj, 1, RyanJsonCreateInt("c", 3)));
  50. TEST_ASSERT_EQUAL_STRING("a", RyanJsonGetKey(RyanJsonGetObjectByIndex(obj, 0)));
  51. TEST_ASSERT_EQUAL_STRING("c", RyanJsonGetKey(RyanJsonGetObjectByIndex(obj, 1)));
  52. TEST_ASSERT_EQUAL_STRING("b", RyanJsonGetKey(RyanJsonGetObjectByIndex(obj, 2)));
  53. RyanJsonDelete(obj);
  54. }
  55. static void testEdgeContainerOpsAddItemToObjectRejectScalarThenRecover(void)
  56. {
  57. // 复杂链路:
  58. // Create(Object) -> AddItemToObject(标量失败) -> AddIntToObject(成功)。
  59. // 目标:验证 AddItemToObject 失败后 Object 仍可稳定复用。
  60. RyanJson_t obj = RyanJsonCreateObject();
  61. TEST_ASSERT_NOT_NULL(obj);
  62. RyanJson_t scalar = RyanJsonCreateInt(NULL, 7);
  63. TEST_ASSERT_NOT_NULL(scalar);
  64. TEST_ASSERT_FALSE_MESSAGE(RyanJsonAddItemToObject(obj, "x", scalar), "AddItemToObject(标量) 应失败");
  65. TEST_ASSERT_EQUAL_UINT32(0U, RyanJsonGetSize(obj));
  66. TEST_ASSERT_TRUE(RyanJsonAddIntToObject(obj, "x", 7));
  67. TEST_ASSERT_EQUAL_INT(7, RyanJsonGetIntValue(RyanJsonGetObjectToKey(obj, "x")));
  68. RyanJsonDelete(obj);
  69. }
  70. static void testEdgeContainerOpsDeleteByIndexArrayOfObjects(void)
  71. {
  72. // 复杂链路:
  73. // Parse(Array<Object>) -> DeleteByIndex -> 结构校验。
  74. // 目标:验证删除 Object Array 元素后剩余元素正确。
  75. RyanJson_t arr = RyanJsonParse("[{\"a\":1},{\"b\":2}]");
  76. TEST_ASSERT_NOT_NULL(arr);
  77. TEST_ASSERT_TRUE(RyanJsonDeleteByIndex(arr, 0));
  78. TEST_ASSERT_EQUAL_UINT32(1U, RyanJsonGetArraySize(arr));
  79. RyanJson_t item = RyanJsonGetObjectByIndex(arr, 0);
  80. TEST_ASSERT_TRUE(RyanJsonIsObject(item));
  81. TEST_ASSERT_TRUE(RyanJsonHasObjectByKey(item, "b"));
  82. RyanJsonDelete(arr);
  83. }
  84. static void testEdgeContainerOpsDeleteByKeyObjectWithArray(void)
  85. {
  86. // 复杂链路:
  87. // Parse(Object) -> DeleteByKey(Array) -> Size 校验。
  88. // 目标:验证删除 Array 字段后 Object 结构正确。
  89. RyanJson_t obj = RyanJsonParse("{\"a\":[1],\"b\":2}");
  90. TEST_ASSERT_NOT_NULL(obj);
  91. TEST_ASSERT_TRUE(RyanJsonDeleteByKey(obj, "a"));
  92. TEST_ASSERT_EQUAL_UINT32(1U, RyanJsonGetSize(obj));
  93. TEST_ASSERT_FALSE(RyanJsonHasObjectByKey(obj, "a"));
  94. TEST_ASSERT_TRUE(RyanJsonHasObjectByKey(obj, "b"));
  95. RyanJsonDelete(obj);
  96. }
  97. static void testEdgeContainerOpsDetachThenInsertBackSameIndex(void)
  98. {
  99. // 复杂链路:
  100. // Parse(Array) -> DetachByIndex -> Insert(同索引) -> Compare。
  101. // 目标:验证同索引回插恢复顺序。
  102. RyanJson_t arr = RyanJsonParse("[1,2,3]");
  103. TEST_ASSERT_NOT_NULL(arr);
  104. RyanJson_t moved = RyanJsonDetachByIndex(arr, 1);
  105. TEST_ASSERT_NOT_NULL(moved);
  106. TEST_ASSERT_TRUE(RyanJsonInsert(arr, 1, moved));
  107. RyanJson_t expect = RyanJsonParse("[1,2,3]");
  108. TEST_ASSERT_NOT_NULL(expect);
  109. TEST_ASSERT_TRUE(RyanJsonCompare(arr, expect));
  110. RyanJsonDelete(expect);
  111. RyanJsonDelete(arr);
  112. }
  113. static void testEdgeContainerOpsDetachThenInsertBackTail(void)
  114. {
  115. // 复杂链路:
  116. // Parse(Array) -> DetachByIndex -> Insert(tail) -> Compare。
  117. // 目标:验证回插到尾部后的顺序。
  118. RyanJson_t arr = RyanJsonParse("[1,2,3]");
  119. TEST_ASSERT_NOT_NULL(arr);
  120. RyanJson_t moved = RyanJsonDetachByIndex(arr, 1);
  121. TEST_ASSERT_NOT_NULL(moved);
  122. TEST_ASSERT_TRUE(RyanJsonInsert(arr, 99, moved));
  123. RyanJson_t expect = RyanJsonParse("[1,3,2]");
  124. TEST_ASSERT_NOT_NULL(expect);
  125. TEST_ASSERT_TRUE(RyanJsonCompare(arr, expect));
  126. RyanJsonDelete(expect);
  127. RyanJsonDelete(arr);
  128. }
  129. static void testEdgeContainerOpsDeleteThenInsertSameKey(void)
  130. {
  131. // 复杂链路:
  132. // Parse(Object) -> DeleteByKey -> Insert(同 key) -> Compare。
  133. // 目标:验证删除后可重新插入同名 key。
  134. RyanJson_t obj = RyanJsonParse("{\"a\":1}");
  135. TEST_ASSERT_NOT_NULL(obj);
  136. TEST_ASSERT_TRUE(RyanJsonDeleteByKey(obj, "a"));
  137. TEST_ASSERT_TRUE(RyanJsonInsert(obj, 0, RyanJsonCreateInt("a", 2)));
  138. TEST_ASSERT_EQUAL_INT(2, RyanJsonGetIntValue(RyanJsonGetObjectByKey(obj, "a")));
  139. RyanJsonDelete(obj);
  140. }
  141. static void testEdgeContainerOpsDeleteThenInsertSameIndexArray(void)
  142. {
  143. // 复杂链路:
  144. // Parse(Array) -> DeleteByIndex -> Insert(同索引) -> Compare。
  145. // 目标:验证删除后可在同索引插入新元素。
  146. RyanJson_t arr = RyanJsonParse("[1,2]");
  147. TEST_ASSERT_NOT_NULL(arr);
  148. TEST_ASSERT_TRUE(RyanJsonDeleteByIndex(arr, 0));
  149. TEST_ASSERT_TRUE(RyanJsonInsert(arr, 0, RyanJsonCreateInt(NULL, 9)));
  150. RyanJson_t expect = RyanJsonParse("[9,2]");
  151. TEST_ASSERT_NOT_NULL(expect);
  152. TEST_ASSERT_TRUE(RyanJsonCompare(arr, expect));
  153. RyanJsonDelete(expect);
  154. RyanJsonDelete(arr);
  155. }
  156. static void testEdgeContainerOpsInsertKeyedItemIntoArray(void)
  157. {
  158. // 复杂链路:
  159. // Parse(Object) -> DetachByKey -> Insert(Array) -> Key 校验。
  160. // 目标:验证 Array 接受携带 key 的节点。
  161. RyanJson_t obj = RyanJsonParse("{\"a\":1}");
  162. TEST_ASSERT_NOT_NULL(obj);
  163. RyanJson_t arr = RyanJsonCreateArray();
  164. TEST_ASSERT_NOT_NULL(arr);
  165. RyanJson_t moved = RyanJsonDetachByKey(obj, "a");
  166. TEST_ASSERT_NOT_NULL(moved);
  167. TEST_ASSERT_TRUE(RyanJsonInsert(arr, 0, moved));
  168. TEST_ASSERT_EQUAL_UINT32(1U, RyanJsonGetArraySize(arr));
  169. RyanJson_t item = RyanJsonGetObjectByIndex(arr, 0);
  170. TEST_ASSERT_TRUE(RyanJsonIsKey(item));
  171. TEST_ASSERT_EQUAL_STRING("a", RyanJsonGetKey(item));
  172. TEST_ASSERT_EQUAL_INT(1, RyanJsonGetIntValue(item));
  173. RyanJsonDelete(arr);
  174. RyanJsonDelete(obj);
  175. }
  176. static void testEdgeContainerOpsDeleteByIndexOnObject(void)
  177. {
  178. // 复杂链路:
  179. // Parse(Object) -> DeleteByIndex -> Key 校验。
  180. // 目标:验证 Object 按索引删除语义。
  181. RyanJson_t obj = RyanJsonParse("{\"a\":1,\"b\":2,\"c\":3}");
  182. TEST_ASSERT_NOT_NULL(obj);
  183. TEST_ASSERT_TRUE(RyanJsonDeleteByIndex(obj, 1));
  184. TEST_ASSERT_TRUE(RyanJsonHasObjectByKey(obj, "a"));
  185. TEST_ASSERT_FALSE(RyanJsonHasObjectByKey(obj, "b"));
  186. TEST_ASSERT_TRUE(RyanJsonHasObjectByKey(obj, "c"));
  187. RyanJsonDelete(obj);
  188. }
  189. static void testEdgeContainerOpsDeleteByIndexOnEmptyObject(void)
  190. {
  191. // 复杂链路:
  192. // Create(Object) -> DeleteByIndex(空 Object) -> 返回 false。
  193. // 目标:验证空 Object 删除失败路径。
  194. RyanJson_t obj = RyanJsonCreateObject();
  195. TEST_ASSERT_NOT_NULL(obj);
  196. TEST_ASSERT_FALSE(RyanJsonDeleteByIndex(obj, 0));
  197. RyanJsonDelete(obj);
  198. }
  199. static void testEdgeContainerOpsDetachByIndexObjectOutOfRange(void)
  200. {
  201. // 复杂链路:
  202. // Parse(Object) -> DetachByIndex(越界) -> 返回 NULL。
  203. // 目标:验证 Object 越界分离失败路径。
  204. RyanJson_t obj = RyanJsonParse("{\"a\":1}");
  205. TEST_ASSERT_NOT_NULL(obj);
  206. TEST_ASSERT_NULL(RyanJsonDetachByIndex(obj, 2));
  207. RyanJsonDelete(obj);
  208. }
  209. static void testEdgeContainerOpsChangeKeyOnArrayElement(void)
  210. {
  211. // 复杂链路:
  212. // Parse(Object) -> DetachByKey -> Insert(Array) -> ChangeKey -> 校验。
  213. // 目标:验证 Array 内带 key 元素可改 key。
  214. RyanJson_t obj = RyanJsonParse("{\"a\":1}");
  215. TEST_ASSERT_NOT_NULL(obj);
  216. RyanJson_t arr = RyanJsonCreateArray();
  217. TEST_ASSERT_NOT_NULL(arr);
  218. RyanJson_t moved = RyanJsonDetachByKey(obj, "a");
  219. TEST_ASSERT_NOT_NULL(moved);
  220. TEST_ASSERT_TRUE(RyanJsonInsert(arr, 0, moved));
  221. TEST_ASSERT_TRUE(RyanJsonChangeKey(moved, "b"));
  222. TEST_ASSERT_EQUAL_STRING("b", RyanJsonGetKey(RyanJsonGetObjectByIndex(arr, 0)));
  223. RyanJsonDelete(arr);
  224. RyanJsonDelete(obj);
  225. }
  226. static void testEdgeContainerOpsDetachThenDeleteByIndexArray(void)
  227. {
  228. // 复杂链路:
  229. // Parse(Array) -> DetachByIndex -> DeleteByIndex -> Compare。
  230. // 目标:验证分离与删除组合后顺序正确。
  231. RyanJson_t arr = RyanJsonParse("[1,2,3,4]");
  232. TEST_ASSERT_NOT_NULL(arr);
  233. RyanJson_t moved = RyanJsonDetachByIndex(arr, 1);
  234. TEST_ASSERT_NOT_NULL(moved);
  235. TEST_ASSERT_TRUE(RyanJsonDeleteByIndex(arr, 1));
  236. RyanJson_t expect = RyanJsonParse("[1,4]");
  237. TEST_ASSERT_NOT_NULL(expect);
  238. TEST_ASSERT_TRUE(RyanJsonCompare(arr, expect));
  239. RyanJsonDelete(expect);
  240. RyanJsonDelete(moved);
  241. RyanJsonDelete(arr);
  242. }
  243. void testEdgeContainerInsertDeleteRunner(void)
  244. {
  245. UnitySetTestFile(__FILE__);
  246. RUN_TEST(testEdgeContainerOpsInsertBeyondSizeArray);
  247. RUN_TEST(testEdgeContainerOpsInsertBeyondSizeObject);
  248. RUN_TEST(testEdgeContainerOpsInsertAtHeadObject);
  249. RUN_TEST(testEdgeContainerOpsInsertReorderObject);
  250. RUN_TEST(testEdgeContainerOpsAddItemToObjectRejectScalarThenRecover);
  251. RUN_TEST(testEdgeContainerOpsDeleteByIndexArrayOfObjects);
  252. RUN_TEST(testEdgeContainerOpsDeleteByKeyObjectWithArray);
  253. RUN_TEST(testEdgeContainerOpsDetachThenInsertBackSameIndex);
  254. RUN_TEST(testEdgeContainerOpsDetachThenInsertBackTail);
  255. RUN_TEST(testEdgeContainerOpsDeleteThenInsertSameKey);
  256. RUN_TEST(testEdgeContainerOpsDeleteThenInsertSameIndexArray);
  257. RUN_TEST(testEdgeContainerOpsInsertKeyedItemIntoArray);
  258. RUN_TEST(testEdgeContainerOpsDeleteByIndexOnObject);
  259. RUN_TEST(testEdgeContainerOpsDeleteByIndexOnEmptyObject);
  260. RUN_TEST(testEdgeContainerOpsDetachByIndexObjectOutOfRange);
  261. RUN_TEST(testEdgeContainerOpsChangeKeyOnArrayElement);
  262. RUN_TEST(testEdgeContainerOpsDetachThenDeleteByIndexArray);
  263. }