mirror of
				https://github.com/bblanchon/ArduinoJson.git
				synced 2025-11-04 00:21:36 +01:00 
			
		
		
		
	Instead of storing a pointer, the function copies the `VariantData`. Benefits: * smaller code * no impact on programs that don't use this feature Drawbacks: * changes to the original variant are not always reflected on the copy * modifying the original from the shallow copy leads to UB
		
			
				
	
	
		
			47 lines
		
	
	
		
			942 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			942 B
		
	
	
	
		
			C++
		
	
	
	
	
	
// ArduinoJson - https://arduinojson.org
 | 
						|
// Copyright © 2014-2022, Benoit BLANCHON
 | 
						|
// MIT License
 | 
						|
 | 
						|
#include <ArduinoJson.h>
 | 
						|
#include <stdint.h>
 | 
						|
#include <catch.hpp>
 | 
						|
 | 
						|
TEST_CASE("JsonVariant::add()") {
 | 
						|
  DynamicJsonDocument doc(4096);
 | 
						|
  JsonVariant var = doc.to<JsonVariant>();
 | 
						|
 | 
						|
  SECTION("add integer to new variant") {
 | 
						|
    var.add(42);
 | 
						|
 | 
						|
    REQUIRE(var.as<std::string>() == "[42]");
 | 
						|
  }
 | 
						|
 | 
						|
  SECTION("add const char* to new variant") {
 | 
						|
    var.add("hello");
 | 
						|
 | 
						|
    REQUIRE(var.as<std::string>() == "[\"hello\"]");
 | 
						|
  }
 | 
						|
 | 
						|
  SECTION("add std::string to new variant") {
 | 
						|
    var.add(std::string("hello"));
 | 
						|
 | 
						|
    REQUIRE(var.as<std::string>() == "[\"hello\"]");
 | 
						|
  }
 | 
						|
 | 
						|
  SECTION("add integer to integer") {
 | 
						|
    var.set(123);
 | 
						|
 | 
						|
    var.add(456);  // no-op
 | 
						|
 | 
						|
    REQUIRE(var.as<std::string>() == "123");
 | 
						|
  }
 | 
						|
 | 
						|
  SECTION("add integer to object") {
 | 
						|
    var["val"] = 123;
 | 
						|
 | 
						|
    var.add(456);  // no-op
 | 
						|
 | 
						|
    REQUIRE(var.as<std::string>() == "{\"val\":123}");
 | 
						|
  }
 | 
						|
}
 |