mirror of
				https://github.com/eledio-devices/thirdparty-ArduinoJson.git
				synced 2025-10-31 16:14:11 +01:00 
			
		
		
		
	Extract VariantProxy from ElementProxy and MemberProxy
				
					
				
			This commit is contained in:
		| @@ -7,10 +7,12 @@ | ||||
|  | ||||
| using namespace ARDUINOJSON_NAMESPACE; | ||||
|  | ||||
| typedef VariantProxy<ElementDataSource<JsonDocument&> > ElementProxy; | ||||
|  | ||||
| TEST_CASE("ElementProxy::add()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   doc.add(); | ||||
|   ElementProxy<JsonDocument&> ep = doc[0]; | ||||
|   ElementProxy ep = doc[0]; | ||||
|  | ||||
|   SECTION("add(int)") { | ||||
|     ep.add(42); | ||||
| @@ -36,7 +38,7 @@ TEST_CASE("ElementProxy::add()") { | ||||
| TEST_CASE("ElementProxy::clear()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   doc.add(); | ||||
|   ElementProxy<JsonDocument&> ep = doc[0]; | ||||
|   ElementProxy ep = doc[0]; | ||||
|  | ||||
|   SECTION("size goes back to zero") { | ||||
|     ep.add(42); | ||||
| @@ -96,7 +98,7 @@ TEST_CASE("ElementProxy::operator==()") { | ||||
| TEST_CASE("ElementProxy::remove()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   doc.add(); | ||||
|   ElementProxy<JsonDocument&> ep = doc[0]; | ||||
|   ElementProxy ep = doc[0]; | ||||
|  | ||||
|   SECTION("remove(int)") { | ||||
|     ep.add(1); | ||||
| @@ -143,7 +145,7 @@ TEST_CASE("ElementProxy::remove()") { | ||||
|  | ||||
| TEST_CASE("ElementProxy::set()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   ElementProxy<JsonDocument&> ep = doc[0]; | ||||
|   ElementProxy ep = doc[0]; | ||||
|  | ||||
|   SECTION("set(int)") { | ||||
|     ep.set(42); | ||||
| @@ -169,7 +171,7 @@ TEST_CASE("ElementProxy::set()") { | ||||
| TEST_CASE("ElementProxy::size()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   doc.add(); | ||||
|   ElementProxy<JsonDocument&> ep = doc[0]; | ||||
|   ElementProxy ep = doc[0]; | ||||
|  | ||||
|   SECTION("returns 0") { | ||||
|     REQUIRE(ep.size() == 0); | ||||
| @@ -191,7 +193,7 @@ TEST_CASE("ElementProxy::size()") { | ||||
| TEST_CASE("ElementProxy::memoryUsage()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   doc.add(); | ||||
|   ElementProxy<JsonDocument&> ep = doc[0]; | ||||
|   ElementProxy ep = doc[0]; | ||||
|  | ||||
|   SECTION("returns 0 for null") { | ||||
|     REQUIRE(ep.memoryUsage() == 0); | ||||
| @@ -205,7 +207,7 @@ TEST_CASE("ElementProxy::memoryUsage()") { | ||||
|  | ||||
| TEST_CASE("ElementProxy::operator[]") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   ElementProxy<JsonDocument&> ep = doc[1]; | ||||
|   ElementProxy ep = doc[1]; | ||||
|  | ||||
|   SECTION("set member") { | ||||
|     ep["world"] = 42; | ||||
| @@ -224,7 +226,7 @@ TEST_CASE("ElementProxy cast to JsonVariantConst") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   doc[0] = "world"; | ||||
|  | ||||
|   const ElementProxy<JsonDocument&> ep = doc[0]; | ||||
|   const ElementProxy ep = doc[0]; | ||||
|  | ||||
|   JsonVariantConst var = ep; | ||||
|  | ||||
| @@ -235,7 +237,7 @@ TEST_CASE("ElementProxy cast to JsonVariant") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   doc[0] = "world"; | ||||
|  | ||||
|   ElementProxy<JsonDocument&> ep = doc[0]; | ||||
|   ElementProxy ep = doc[0]; | ||||
|  | ||||
|   JsonVariant var = ep; | ||||
|  | ||||
|   | ||||
| @@ -7,9 +7,11 @@ | ||||
|  | ||||
| using namespace ARDUINOJSON_NAMESPACE; | ||||
|  | ||||
| typedef VariantProxy<MemberDataSource<JsonDocument&, const char*> > MemberProxy; | ||||
|  | ||||
| TEST_CASE("MemberProxy::add()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   SECTION("add(int)") { | ||||
|     mp.add(42); | ||||
| @@ -26,7 +28,7 @@ TEST_CASE("MemberProxy::add()") { | ||||
|  | ||||
| TEST_CASE("MemberProxy::clear()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   SECTION("size goes back to zero") { | ||||
|     mp.add(42); | ||||
| @@ -85,7 +87,7 @@ TEST_CASE("MemberProxy::operator==()") { | ||||
|  | ||||
| TEST_CASE("MemberProxy::containsKey()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   SECTION("containsKey(const char*)") { | ||||
|     mp["key"] = "value"; | ||||
| @@ -136,7 +138,7 @@ TEST_CASE("MemberProxy::operator|()") { | ||||
|  | ||||
| TEST_CASE("MemberProxy::remove()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   SECTION("remove(int)") { | ||||
|     mp.add(1); | ||||
| @@ -183,7 +185,7 @@ TEST_CASE("MemberProxy::remove()") { | ||||
|  | ||||
| TEST_CASE("MemberProxy::set()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   SECTION("set(int)") { | ||||
|     mp.set(42); | ||||
| @@ -208,7 +210,7 @@ TEST_CASE("MemberProxy::set()") { | ||||
|  | ||||
| TEST_CASE("MemberProxy::size()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   SECTION("returns 0") { | ||||
|     REQUIRE(mp.size() == 0); | ||||
| @@ -231,7 +233,7 @@ TEST_CASE("MemberProxy::size()") { | ||||
|  | ||||
| TEST_CASE("MemberProxy::memoryUsage()") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   SECTION("returns 0 when null") { | ||||
|     REQUIRE(mp.memoryUsage() == 0); | ||||
| @@ -245,7 +247,7 @@ TEST_CASE("MemberProxy::memoryUsage()") { | ||||
|  | ||||
| TEST_CASE("MemberProxy::operator[]") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   SECTION("set member") { | ||||
|     mp["world"] = 42; | ||||
| @@ -264,7 +266,7 @@ TEST_CASE("MemberProxy cast to JsonVariantConst") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   doc["hello"] = "world"; | ||||
|  | ||||
|   const MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   const MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   JsonVariantConst var = mp; | ||||
|  | ||||
| @@ -275,7 +277,7 @@ TEST_CASE("MemberProxy cast to JsonVariant") { | ||||
|   DynamicJsonDocument doc(4096); | ||||
|   doc["hello"] = "world"; | ||||
|  | ||||
|   MemberProxy<JsonDocument&, const char*> mp = doc["hello"]; | ||||
|   MemberProxy mp = doc["hello"]; | ||||
|  | ||||
|   JsonVariant var = mp; | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user