deserializeVariant.cpp 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. // ArduinoJson - arduinojson.org
  2. // Copyright Benoit Blanchon 2014-2018
  3. // MIT License
  4. #include <ArduinoJson.h>
  5. #include <catch.hpp>
  6. template <typename T, typename U>
  7. static void check(const char* input, U expected) {
  8. DynamicJsonVariant variant;
  9. MsgPackError error = deserializeMsgPack(variant, input);
  10. REQUIRE(error == MsgPackError::Ok);
  11. REQUIRE(variant.is<T>());
  12. REQUIRE(variant.as<T>() == expected);
  13. }
  14. TEST_CASE("deserializeMsgPack(JsonVariant&)") {
  15. SECTION("nil") {
  16. const char* nil = 0; // ArduinoJson uses a string for null
  17. check<const char*>("\xc0", nil);
  18. }
  19. SECTION("bool") {
  20. check<bool>("\xc2", false);
  21. check<bool>("\xc3", true);
  22. }
  23. SECTION("positive fixint") {
  24. check<int>("\x00", 0);
  25. check<int>("\x7F", 127);
  26. }
  27. SECTION("negative fixint") {
  28. check<int>("\xe0", -32);
  29. check<int>("\xff", -1);
  30. }
  31. SECTION("uint 8") {
  32. check<int>("\xcc\x00", 0);
  33. check<int>("\xcc\xff", 255);
  34. }
  35. SECTION("uint 16") {
  36. check<int>("\xcd\x00\x00", 0);
  37. check<int>("\xcd\xFF\xFF", 65535);
  38. check<int>("\xcd\x30\x39", 12345);
  39. }
  40. SECTION("uint 32") {
  41. check<uint32_t>("\xCE\x00\x00\x00\x00", 0x00000000U);
  42. check<uint32_t>("\xCE\xFF\xFF\xFF\xFF", 0xFFFFFFFFU);
  43. check<uint32_t>("\xCE\x12\x34\x56\x78", 0x12345678U);
  44. }
  45. SECTION("uint 64") {
  46. #if ARDUINOJSON_USE_LONG_LONG || ARDUINOJSON_USE_INT64
  47. check<uint64_t>("\xCF\x00\x00\x00\x00\x00\x00\x00\x00", 0U);
  48. check<uint64_t>("\xCF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF",
  49. 0xFFFFFFFFFFFFFFFFU);
  50. check<uint64_t>("\xCF\x12\x34\x56\x78\x9A\xBC\xDE\xF0",
  51. 0x123456789ABCDEF0U);
  52. #else
  53. check<uint32_t>("\xCF\x00\x00\x00\x00\x00\x00\x00\x00", 0U);
  54. check<uint32_t>("\xCF\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 0xFFFFFFFF);
  55. check<uint32_t>("\xCF\x12\x34\x56\x78\x9A\xBC\xDE\xF0", 0x9ABCDEF0);
  56. #endif
  57. }
  58. SECTION("int 8") {
  59. check<int>("\xd0\x00", 0);
  60. check<int>("\xd0\xff", -1);
  61. }
  62. SECTION("int 16") {
  63. check<int>("\xD1\x00\x00", 0);
  64. check<int>("\xD1\xFF\xFF", -1);
  65. check<int>("\xD1\xCF\xC7", -12345);
  66. }
  67. SECTION("int 32") {
  68. check<int>("\xD2\x00\x00\x00\x00", 0);
  69. check<int>("\xD2\xFF\xFF\xFF\xFF", -1);
  70. check<int>("\xD2\xB6\x69\xFD\x2E", -1234567890);
  71. }
  72. SECTION("int 64") {
  73. #if ARDUINOJSON_USE_LONG_LONG || ARDUINOJSON_USE_INT64
  74. check<uint64_t>("\xD3\x00\x00\x00\x00\x00\x00\x00\x00", 0U);
  75. check<uint64_t>("\xD3\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF",
  76. 0xFFFFFFFFFFFFFFFFU);
  77. check<uint64_t>("\xD3\x12\x34\x56\x78\x9A\xBC\xDE\xF0",
  78. 0x123456789ABCDEF0U);
  79. #else
  80. check<uint32_t>("\xD3\x00\x00\x00\x00\x00\x00\x00\x00", 0U);
  81. check<uint32_t>("\xD3\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFF", 0xFFFFFFFF);
  82. check<uint32_t>("\xD3\x12\x34\x56\x78\x9A\xBC\xDE\xF0", 0x9ABCDEF0);
  83. #endif
  84. }
  85. SECTION("float 32") {
  86. check<double>("\xCA\x00\x00\x00\x00", 0.0f);
  87. check<double>("\xCA\x40\x48\xF5\xC3", 3.14f);
  88. }
  89. SECTION("float 64") {
  90. check<double>("\xCB\x00\x00\x00\x00\x00\x00\x00\x00", 0.0);
  91. check<double>("\xCB\x40\x09\x21\xCA\xC0\x83\x12\x6F", 3.1415);
  92. }
  93. SECTION("fixstr") {
  94. check<const char*>("\xA0", std::string(""));
  95. check<const char*>("\xABhello world", std::string("hello world"));
  96. check<const char*>("\xBFhello world hello world hello !",
  97. std::string("hello world hello world hello !"));
  98. }
  99. SECTION("str 8") {
  100. check<const char*>("\xd9\x05hello", std::string("hello"));
  101. }
  102. SECTION("str 16") {
  103. check<const char*>("\xda\x00\x05hello", std::string("hello"));
  104. }
  105. SECTION("str 32") {
  106. check<const char*>("\xdb\x00\x00\x00\x05hello", std::string("hello"));
  107. }
  108. SECTION("fixarray") {
  109. DynamicJsonVariant variant;
  110. SECTION("empty") {
  111. const char* input = "\x90";
  112. MsgPackError error = deserializeMsgPack(variant, input);
  113. REQUIRE(error == MsgPackError::Ok);
  114. REQUIRE(variant.size() == 0);
  115. }
  116. SECTION("two integers") {
  117. const char* input = "\x92\x01\x02";
  118. MsgPackError error = deserializeMsgPack(variant, input);
  119. REQUIRE(error == MsgPackError::Ok);
  120. REQUIRE(variant.size() == 2);
  121. REQUIRE(variant[0] == 1);
  122. REQUIRE(variant[1] == 2);
  123. }
  124. }
  125. SECTION("array 16") {
  126. DynamicJsonVariant variant;
  127. SECTION("empty") {
  128. const char* input = "\xDC\x00\x00";
  129. MsgPackError error = deserializeMsgPack(variant, input);
  130. REQUIRE(error == MsgPackError::Ok);
  131. REQUIRE(variant.size() == 0);
  132. }
  133. SECTION("two strings") {
  134. const char* input = "\xDC\x00\x02\xA5hello\xA5world";
  135. MsgPackError error = deserializeMsgPack(variant, input);
  136. REQUIRE(error == MsgPackError::Ok);
  137. REQUIRE(variant.size() == 2);
  138. REQUIRE(variant[0] == "hello");
  139. REQUIRE(variant[1] == "world");
  140. }
  141. }
  142. SECTION("array 32") {
  143. DynamicJsonVariant variant;
  144. SECTION("empty") {
  145. const char* input = "\xDD\x00\x00\x00\x00";
  146. MsgPackError error = deserializeMsgPack(variant, input);
  147. REQUIRE(error == MsgPackError::Ok);
  148. REQUIRE(variant.size() == 0);
  149. }
  150. SECTION("two floats") {
  151. const char* input =
  152. "\xDD\x00\x00\x00\x02\xCA\x00\x00\x00\x00\xCA\x40\x48\xF5\xC3";
  153. MsgPackError error = deserializeMsgPack(variant, input);
  154. REQUIRE(error == MsgPackError::Ok);
  155. REQUIRE(variant.size() == 2);
  156. REQUIRE(variant[0] == 0.0f);
  157. REQUIRE(variant[1] == 3.14f);
  158. }
  159. }
  160. SECTION("fixmap") {
  161. DynamicJsonVariant variant;
  162. SECTION("empty") {
  163. const char* input = "\x80";
  164. MsgPackError error = deserializeMsgPack(variant, input);
  165. REQUIRE(error == MsgPackError::Ok);
  166. REQUIRE(variant.size() == 0);
  167. }
  168. SECTION("two integers") {
  169. const char* input = "\x82\xA3one\x01\xA3two\x02";
  170. MsgPackError error = deserializeMsgPack(variant, input);
  171. REQUIRE(error == MsgPackError::Ok);
  172. REQUIRE(variant.size() == 2);
  173. REQUIRE(variant["one"] == 1);
  174. REQUIRE(variant["two"] == 2);
  175. }
  176. }
  177. SECTION("map 16") {
  178. DynamicJsonVariant variant;
  179. SECTION("empty") {
  180. const char* input = "\xDE\x00\x00";
  181. MsgPackError error = deserializeMsgPack(variant, input);
  182. REQUIRE(error == MsgPackError::Ok);
  183. REQUIRE(variant.size() == 0);
  184. }
  185. SECTION("two strings") {
  186. const char* input = "\xDE\x00\x02\xA1H\xA5hello\xA1W\xA5world";
  187. MsgPackError error = deserializeMsgPack(variant, input);
  188. REQUIRE(error == MsgPackError::Ok);
  189. REQUIRE(variant.size() == 2);
  190. REQUIRE(variant["H"] == "hello");
  191. REQUIRE(variant["W"] == "world");
  192. }
  193. }
  194. SECTION("map 32") {
  195. DynamicJsonVariant variant;
  196. SECTION("empty") {
  197. const char* input = "\xDF\x00\x00\x00\x00";
  198. MsgPackError error = deserializeMsgPack(variant, input);
  199. REQUIRE(error == MsgPackError::Ok);
  200. REQUIRE(variant.size() == 0);
  201. }
  202. SECTION("two floats") {
  203. const char* input =
  204. "\xDF\x00\x00\x00\x02\xA4zero\xCA\x00\x00\x00\x00\xA2pi\xCA\x40\x48"
  205. "\xF5\xC3";
  206. MsgPackError error = deserializeMsgPack(variant, input);
  207. REQUIRE(error == MsgPackError::Ok);
  208. REQUIRE(variant.size() == 2);
  209. REQUIRE(variant["zero"] == 0.0f);
  210. REQUIRE(variant["pi"] == 3.14f);
  211. }
  212. }
  213. }