| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331 |
- // ArduinoJson - arduinojson.org
- // Copyright Benoit Blanchon 2014-2023
- // MIT License
- #include <ArduinoJson.h>
- #include <catch.hpp>
- #if defined(__clang__)
- #pragma clang diagnostic ignored "-Wvla-extension"
- #define CONFLICTS_WITH_BUILTIN_OPERATOR
- #elif defined(__GNUC__)
- #pragma GCC diagnostic ignored "-Wvla"
- #else
- #define VLA_NOT_SUPPORTED
- #endif
- #ifndef VLA_NOT_SUPPORTED
- TEST_CASE("Variable Length Array") {
- SECTION("ParseArray") {
- int i = 8;
- char vla[i];
- strcpy(vla, "[42]");
- StaticJsonBuffer<JSON_ARRAY_SIZE(1)> jsonBuffer;
- JsonArray& arr = jsonBuffer.parseArray(vla);
- REQUIRE(true == arr.success());
- }
- SECTION("ParseObject") {
- int i = 16;
- char vla[i];
- strcpy(vla, "{\"a\":42}");
- StaticJsonBuffer<JSON_OBJECT_SIZE(1)> jsonBuffer;
- JsonObject& obj = jsonBuffer.parseObject(vla);
- REQUIRE(true == obj.success());
- }
- SECTION("Parse") {
- int i = 16;
- char vla[i];
- strcpy(vla, "42");
- StaticJsonBuffer<1> jsonBuffer;
- JsonVariant variant = jsonBuffer.parse(vla);
- REQUIRE(42 == variant.as<int>());
- }
- SECTION("JsonVariant_Constructor") {
- int i = 16;
- char vla[i];
- strcpy(vla, "42");
- JsonVariant variant(vla);
- REQUIRE(42 == variant.as<int>());
- }
- SECTION("JsonVariant_Assign") {
- int i = 16;
- char vla[i];
- strcpy(vla, "42");
- JsonVariant variant(666);
- variant = vla;
- REQUIRE(42 == variant.as<int>());
- }
- #ifndef CONFLICTS_WITH_BUILTIN_OPERATOR
- SECTION("JsonVariant_Subscript") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- JsonVariant variant = jsonBuffer.parseObject("{\"hello\":\"world\"}");
- REQUIRE(std::string("world") == variant[vla]);
- }
- #endif
- #ifndef CONFLICTS_WITH_BUILTIN_OPERATOR
- SECTION("JsonVariant_Subscript_Const") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- const JsonVariant variant = jsonBuffer.parseObject("{\"hello\":\"world\"}");
- REQUIRE(std::string("world") == variant[vla]);
- }
- #endif
- SECTION("JsonVariant_Equals") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- const JsonVariant variant = "hello";
- REQUIRE((vla == variant));
- REQUIRE((variant == vla));
- REQUIRE_FALSE((vla != variant));
- REQUIRE_FALSE((variant != vla));
- }
- SECTION("JsonVariant_Differs") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- const JsonVariant variant = "world";
- REQUIRE((vla != variant));
- REQUIRE((variant != vla));
- REQUIRE_FALSE((vla == variant));
- REQUIRE_FALSE((variant == vla));
- }
- #ifndef CONFLICTS_WITH_BUILTIN_OPERATOR
- SECTION("JsonObject_Subscript") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.createObject();
- obj[vla] = "world";
- REQUIRE(std::string("world") == obj["hello"]);
- }
- #endif
- SECTION("JsonObject_Subscript_Assign") { // issue #416
- int i = 32;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.createObject();
- obj["hello"] = vla;
- REQUIRE(std::string("world") == obj["hello"].as<char*>());
- }
- SECTION("JsonObject_Subscript_Set") {
- int i = 32;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.createObject();
- obj["hello"].set(vla);
- REQUIRE(std::string("world") == obj["hello"].as<char*>());
- }
- #ifndef CONFLICTS_WITH_BUILTIN_OPERATOR
- SECTION("JsonObject_Subscript_Const") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- const JsonObject& obj = jsonBuffer.parseObject("{\"hello\":\"world\"}");
- REQUIRE(std::string("world") == obj[vla]);
- }
- #endif
- SECTION("JsonObject_Get") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.parseObject("{\"hello\":\"world\"}");
- REQUIRE(std::string("world") == obj.get<char*>(vla));
- }
- SECTION("JsonObject_Set_Key") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.createObject();
- obj.set(vla, "world");
- REQUIRE(std::string("world") == obj["hello"]);
- }
- SECTION("JsonObject_Set_Value") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.createObject();
- obj.set("hello", vla);
- REQUIRE(std::string("world") == obj["hello"]);
- }
- SECTION("JsonObject_Set_KeyAndValue") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.createObject();
- obj.set(vla, vla);
- REQUIRE(std::string("world") == obj["world"]);
- }
- SECTION("JsonObject_ContainsKey") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- const JsonObject& obj = jsonBuffer.parseObject("{\"hello\":\"world\"}");
- REQUIRE(true == obj.containsKey(vla));
- }
- SECTION("JsonObject_Remove") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.parseObject("{\"hello\":\"world\"}");
- obj.remove(vla);
- REQUIRE(0 == obj.size());
- }
- SECTION("JsonObject_Is") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.parseObject("{\"hello\":42}");
- REQUIRE(true == obj.is<int>(vla));
- }
- SECTION("JsonObject_CreateNestedArray") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.createObject();
- obj.createNestedArray(vla);
- }
- SECTION("JsonObject_CreateNestedObject") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonBuffer jsonBuffer;
- JsonObject& obj = jsonBuffer.createObject();
- obj.createNestedObject(vla);
- }
- SECTION("JsonArray_Add") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonBuffer jsonBuffer;
- JsonArray& arr = jsonBuffer.createArray();
- arr.add(vla);
- REQUIRE(std::string("world") == arr[0]);
- }
- SECTION("JsonArray_Set") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonBuffer jsonBuffer;
- JsonArray& arr = jsonBuffer.createArray();
- arr.add("hello");
- arr.set(0, vla);
- REQUIRE(std::string("world") == arr[0]);
- }
- SECTION("JsonArraySubscript_Set") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonBuffer jsonBuffer;
- JsonArray& arr = jsonBuffer.createArray();
- arr.add("hello");
- arr[0].set(vla);
- REQUIRE(std::string("world") == arr[0]);
- }
- SECTION("JsonArraySubscript_Assign") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonBuffer jsonBuffer;
- JsonArray& arr = jsonBuffer.createArray();
- arr.add("hello");
- arr[0] = vla;
- REQUIRE(std::string("world") == arr[0]);
- }
- }
- #endif
|