// ArduinoJson - https://arduinojson.org // Copyright © 2014-2025, Benoit BLANCHON // MIT License #include #include #include "Allocators.hpp" #include "Literals.hpp" TEST_CASE("JsonVariant::set(JsonVariant)") { KillswitchAllocator killswitch; SpyingAllocator spyingAllocator(&killswitch); JsonDocument doc1(&spyingAllocator); JsonDocument doc2(&spyingAllocator); JsonVariant var1 = doc1.to(); JsonVariant var2 = doc2.to(); SECTION("stores JsonArray by copy") { JsonArray arr = doc2.to(); JsonObject obj = arr.add(); obj["hello"] = "world"; var1.set(arr); arr[0] = 666; REQUIRE(var1.as() == "[{\"hello\":\"world\"}]"); } SECTION("stores JsonObject by copy") { JsonObject obj = doc2.to(); JsonArray arr = obj["value"].to(); arr.add(42); var1.set(obj); obj["value"] = 666; REQUIRE(var1.as() == "{\"value\":[42]}"); } SECTION("stores string literals by copy") { var1.set("hello!!"); spyingAllocator.clearLog(); var2.set(var1); REQUIRE(spyingAllocator.log() == AllocatorLog{ Allocate(sizeofString("hello!!")), }); } SECTION("stores char* by copy") { char str[] = "hello!!"; var1.set(str); spyingAllocator.clearLog(); var2.set(var1); REQUIRE(spyingAllocator.log() == AllocatorLog{ Allocate(sizeofString("hello!!")), }); } SECTION("fails gracefully if string allocation fails") { char str[] = "hello!!"; var1.set(str); killswitch.on(); spyingAllocator.clearLog(); var2.set(var1); REQUIRE(doc2.overflowed() == true); REQUIRE(spyingAllocator.log() == AllocatorLog{ AllocateFail(sizeofString("hello!!")), }); } SECTION("stores std::string by copy") { var1.set("hello!!"_s); spyingAllocator.clearLog(); var2.set(var1); REQUIRE(spyingAllocator.log() == AllocatorLog{ Allocate(sizeofString("hello!!")), }); } SECTION("stores Serialized by copy") { var1.set(serialized("hello!!", 7)); spyingAllocator.clearLog(); var2.set(var1); REQUIRE(spyingAllocator.log() == AllocatorLog{ Allocate(sizeofString("hello!!")), }); } SECTION("stores Serialized by copy") { char str[] = "hello!!"; var1.set(serialized(str, 7)); spyingAllocator.clearLog(); var2.set(var1); REQUIRE(spyingAllocator.log() == AllocatorLog{ Allocate(sizeofString("hello!!")), }); } SECTION("stores Serialized by copy") { var1.set(serialized("hello!!"_s)); spyingAllocator.clearLog(); var2.set(var1); REQUIRE(spyingAllocator.log() == AllocatorLog{ Allocate(sizeofString("hello!!")), }); } SECTION("fails gracefully if raw string allocation fails") { var1.set(serialized("hello!!"_s)); killswitch.on(); spyingAllocator.clearLog(); var2.set(var1); REQUIRE(doc2.overflowed() == true); REQUIRE(spyingAllocator.log() == AllocatorLog{ AllocateFail(sizeofString("hello!!")), }); } SECTION("destination is unbound") { JsonVariant unboundVariant; unboundVariant.set(var1); REQUIRE(unboundVariant.isUnbound()); REQUIRE(unboundVariant.isNull()); } }