| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337 |
- // ArduinoJson - arduinojson.org
- // Copyright Benoit Blanchon 2014-2018
- // 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("deserializeJson()") {
- int i = 9;
- char vla[i];
- strcpy(vla, "{\"a\":42}");
- StaticJsonDocument<JSON_OBJECT_SIZE(1)> doc;
- JsonError err = deserializeJson(doc, vla);
- REQUIRE(err == JsonError::Ok);
- }
- SECTION("deserializeMsgPack()") {
- int i = 16;
- char vla[i];
- memcpy(vla, "\xDE\x00\x01\xA5Hello\xA5world", 15);
- StaticJsonDocument<JSON_OBJECT_SIZE(1)> doc;
- MsgPackError err = deserializeMsgPack(doc, vla);
- REQUIRE(err == MsgPackError::Ok);
- }
- SECTION("JsonVariant") {
- SECTION("constructor") {
- int i = 16;
- char vla[i];
- strcpy(vla, "42");
- JsonVariant variant(vla);
- REQUIRE(42 == variant.as<int>());
- }
- SECTION("operator=") {
- 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("operator[]") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- deserializeJson(doc, "{\"hello\":\"world\"}");
- JsonVariant variant = doc.as<JsonVariant>();
- REQUIRE(std::string("world") == variant[vla]);
- }
- #endif
- #ifndef CONFLICTS_WITH_BUILTIN_OPERATOR
- SECTION("operator[] const") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- deserializeJson(doc, "{\"hello\":\"world\"}");
- const JsonVariant variant = doc.as<JsonVariant>();
- REQUIRE(std::string("world") == variant[vla]);
- }
- #endif
- SECTION("operator==") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- JsonVariant variant;
- variant = "hello";
- REQUIRE((vla == variant));
- REQUIRE((variant == vla));
- REQUIRE_FALSE((vla != variant));
- REQUIRE_FALSE((variant != vla));
- }
- SECTION("operator!=") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- JsonVariant variant;
- variant = "world";
- REQUIRE((vla != variant));
- REQUIRE((variant != vla));
- REQUIRE_FALSE((vla == variant));
- REQUIRE_FALSE((variant == vla));
- }
- }
- SECTION("JsonObject") {
- #ifndef CONFLICTS_WITH_BUILTIN_OPERATOR
- SECTION("operator[]") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- JsonObject& obj = doc.to<JsonObject>();
- obj[vla] = "world";
- REQUIRE(std::string("world") == obj["hello"]);
- }
- #endif
- #ifndef CONFLICTS_WITH_BUILTIN_OPERATOR
- SECTION("operator[] const") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- deserializeJson(doc, "{\"hello\":\"world\"}");
- JsonObject& obj = doc.as<JsonObject>();
- REQUIRE(std::string("world") == obj[vla]);
- }
- #endif
- SECTION("get()") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- deserializeJson(doc, "{\"hello\":\"world\"}");
- JsonObject& obj = doc.as<JsonObject>();
- REQUIRE(std::string("world") == obj.get<char*>(vla));
- }
- SECTION("set() key") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- JsonObject& obj = doc.to<JsonObject>();
- obj.set(vla, "world");
- REQUIRE(std::string("world") == obj["hello"]);
- }
- SECTION("set() value") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonDocument doc;
- JsonObject& obj = doc.to<JsonObject>();
- obj.set("hello", vla);
- REQUIRE(std::string("world") == obj["hello"]);
- }
- SECTION("set() key&value") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonDocument doc;
- JsonObject& obj = doc.to<JsonObject>();
- obj.set(vla, vla);
- REQUIRE(std::string("world") == obj["world"]);
- }
- SECTION("containsKey()") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- deserializeJson(doc, "{\"hello\":\"world\"}");
- JsonObject& obj = doc.as<JsonObject>();
- REQUIRE(true == obj.containsKey(vla));
- }
- SECTION("remove()") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- deserializeJson(doc, "{\"hello\":\"world\"}");
- JsonObject& obj = doc.as<JsonObject>();
- obj.remove(vla);
- REQUIRE(0 == obj.size());
- }
- SECTION("is<T>()") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- deserializeJson(doc, "{\"hello\":42}");
- JsonObject& obj = doc.as<JsonObject>();
- REQUIRE(true == obj.is<int>(vla));
- }
- SECTION("createNestedArray()") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- JsonObject& obj = doc.to<JsonObject>();
- obj.createNestedArray(vla);
- }
- SECTION("createNestedObject()") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc;
- JsonObject& obj = doc.to<JsonObject>();
- obj.createNestedObject(vla);
- }
- }
- SECTION("JsonObjectSubscript") {
- SECTION("operator=") { // issue #416
- int i = 32;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonDocument doc;
- JsonObject& obj = doc.to<JsonObject>();
- obj["hello"] = vla;
- REQUIRE(std::string("world") == obj["hello"].as<char*>());
- }
- SECTION("set()") {
- int i = 32;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonDocument doc;
- JsonObject& obj = doc.to<JsonObject>();
- obj["hello"].set(vla);
- REQUIRE(std::string("world") == obj["hello"].as<char*>());
- }
- }
- SECTION("JsonArray") {
- SECTION("add()") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonDocument doc;
- JsonArray& arr = doc.to<JsonArray>();
- arr.add(vla);
- REQUIRE(std::string("world") == arr[0]);
- }
- SECTION("set()") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonDocument doc;
- JsonArray& arr = doc.to<JsonArray>();
- arr.add("hello");
- arr.set(0, vla);
- REQUIRE(std::string("world") == arr[0]);
- }
- }
- SECTION("JsonArraySubscript") {
- SECTION("set()") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonDocument doc;
- JsonArray& arr = doc.to<JsonArray>();
- arr.add("hello");
- arr[0].set(vla);
- REQUIRE(std::string("world") == arr[0]);
- }
- SECTION("operator=") {
- int i = 16;
- char vla[i];
- strcpy(vla, "world");
- DynamicJsonDocument doc;
- JsonArray& arr = doc.to<JsonArray>();
- arr.add("hello");
- arr[0] = vla;
- REQUIRE(std::string("world") == arr[0]);
- }
- }
- }
- #endif
|