mirror of
				https://github.com/eledio-devices/thirdparty-ArduinoJson.git
				synced 2025-10-31 16:14:11 +01:00 
			
		
		
		
	Added JsonDocument::overflowed() (closes #1358)
				
					
				
			This commit is contained in:
		| @@ -11,6 +11,7 @@ add_executable(JsonDocumentTests | ||||
| 	DynamicJsonDocument.cpp | ||||
| 	isNull.cpp | ||||
| 	nesting.cpp | ||||
| 	overflowed.cpp | ||||
| 	remove.cpp | ||||
| 	shrinkToFit.cpp | ||||
| 	size.cpp | ||||
|   | ||||
							
								
								
									
										79
									
								
								extras/tests/JsonDocument/overflowed.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								extras/tests/JsonDocument/overflowed.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,79 @@ | ||||
| // ArduinoJson - arduinojson.org | ||||
| // Copyright Benoit Blanchon 2014-2020 | ||||
| // MIT License | ||||
|  | ||||
| #include <ArduinoJson.h> | ||||
| #include <catch.hpp> | ||||
|  | ||||
| TEST_CASE("JsonDocument::overflowed()") { | ||||
|   SECTION("returns false on a fresh object") { | ||||
|     StaticJsonDocument<0> doc; | ||||
|     CHECK(doc.overflowed() == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("returns true after a failed insertion") { | ||||
|     StaticJsonDocument<0> doc; | ||||
|     doc.add(0); | ||||
|     CHECK(doc.overflowed() == true); | ||||
|   } | ||||
|  | ||||
|   SECTION("returns false after successful insertion") { | ||||
|     StaticJsonDocument<JSON_ARRAY_SIZE(1)> doc; | ||||
|     doc.add(0); | ||||
|     CHECK(doc.overflowed() == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("returns true after a failed string copy") { | ||||
|     StaticJsonDocument<JSON_ARRAY_SIZE(1)> doc; | ||||
|     doc.add(std::string("example")); | ||||
|     CHECK(doc.overflowed() == true); | ||||
|   } | ||||
|  | ||||
|   SECTION("returns false after a successful string copy") { | ||||
|     StaticJsonDocument<JSON_ARRAY_SIZE(1) + 8> doc; | ||||
|     doc.add(std::string("example")); | ||||
|     CHECK(doc.overflowed() == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("returns true after a failed deserialization") { | ||||
|     StaticJsonDocument<JSON_ARRAY_SIZE(1)> doc; | ||||
|     deserializeJson(doc, "[\"example\"]"); | ||||
|     CHECK(doc.overflowed() == true); | ||||
|   } | ||||
|  | ||||
|   SECTION("returns false after a successful deserialization") { | ||||
|     StaticJsonDocument<JSON_ARRAY_SIZE(1) + 8> doc; | ||||
|     deserializeJson(doc, "[\"example\"]"); | ||||
|     CHECK(doc.overflowed() == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("returns false after clear()") { | ||||
|     StaticJsonDocument<0> doc; | ||||
|     doc.add(0); | ||||
|     doc.clear(); | ||||
|     CHECK(doc.overflowed() == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("remains false after shrinkToFit()") { | ||||
|     DynamicJsonDocument doc(JSON_ARRAY_SIZE(1)); | ||||
|     doc.add(0); | ||||
|     doc.shrinkToFit(); | ||||
|     CHECK(doc.overflowed() == false); | ||||
|   } | ||||
|  | ||||
|   SECTION("remains true after shrinkToFit()") { | ||||
|     DynamicJsonDocument doc(JSON_ARRAY_SIZE(1)); | ||||
|     doc.add(0); | ||||
|     doc.add(0); | ||||
|     doc.shrinkToFit(); | ||||
|     CHECK(doc.overflowed() == true); | ||||
|   } | ||||
|  | ||||
|   SECTION("return false after garbageCollect()") { | ||||
|     DynamicJsonDocument doc(JSON_ARRAY_SIZE(1)); | ||||
|     doc.add(0); | ||||
|     doc.add(0); | ||||
|     doc.garbageCollect(); | ||||
|     CHECK(doc.overflowed() == false); | ||||
|   } | ||||
| } | ||||
| @@ -12,9 +12,9 @@ TEST_CASE("StringCopier") { | ||||
|  | ||||
|   SECTION("Works when buffer is big enough") { | ||||
|     MemoryPool pool(buffer, addPadding(JSON_STRING_SIZE(6))); | ||||
|     StringCopier str; | ||||
|     StringCopier str(pool); | ||||
|  | ||||
|     str.startString(&pool); | ||||
|     str.startString(); | ||||
|     str.append("hello"); | ||||
|     str.append('\0'); | ||||
|  | ||||
| @@ -24,9 +24,9 @@ TEST_CASE("StringCopier") { | ||||
|  | ||||
|   SECTION("Returns null when too small") { | ||||
|     MemoryPool pool(buffer, sizeof(void*)); | ||||
|     StringCopier str; | ||||
|     StringCopier str(pool); | ||||
|  | ||||
|     str.startString(&pool); | ||||
|     str.startString(); | ||||
|     str.append("hello world!"); | ||||
|  | ||||
|     REQUIRE(str.isValid() == false); | ||||
| @@ -34,22 +34,22 @@ TEST_CASE("StringCopier") { | ||||
|  | ||||
|   SECTION("Increases size of memory pool") { | ||||
|     MemoryPool pool(buffer, addPadding(JSON_STRING_SIZE(6))); | ||||
|     StringCopier str; | ||||
|     StringCopier str(pool); | ||||
|  | ||||
|     str.startString(&pool); | ||||
|     str.startString(); | ||||
|     str.append('h'); | ||||
|     str.save(&pool); | ||||
|     str.save(); | ||||
|  | ||||
|     REQUIRE(1 == pool.size()); | ||||
|   } | ||||
| } | ||||
|  | ||||
| static const char* addStringToPool(MemoryPool* pool, const char* s) { | ||||
|   StringCopier str; | ||||
|   str.startString(pool); | ||||
| static const char* addStringToPool(MemoryPool& pool, const char* s) { | ||||
|   StringCopier str(pool); | ||||
|   str.startString(); | ||||
|   str.append(s); | ||||
|   str.append('\0'); | ||||
|   return str.save(pool); | ||||
|   return str.save(); | ||||
| } | ||||
|  | ||||
| TEST_CASE("StringCopier::save() deduplicates strings") { | ||||
| @@ -57,9 +57,9 @@ TEST_CASE("StringCopier::save() deduplicates strings") { | ||||
|   MemoryPool pool(buffer, 4096); | ||||
|  | ||||
|   SECTION("Basic") { | ||||
|     const char* s1 = addStringToPool(&pool, "hello"); | ||||
|     const char* s2 = addStringToPool(&pool, "world"); | ||||
|     const char* s3 = addStringToPool(&pool, "hello"); | ||||
|     const char* s1 = addStringToPool(pool, "hello"); | ||||
|     const char* s2 = addStringToPool(pool, "world"); | ||||
|     const char* s3 = addStringToPool(pool, "hello"); | ||||
|  | ||||
|     REQUIRE(s1 == s3); | ||||
|     REQUIRE(s2 != s3); | ||||
| @@ -67,16 +67,16 @@ TEST_CASE("StringCopier::save() deduplicates strings") { | ||||
|   } | ||||
|  | ||||
|   SECTION("Requires terminator") { | ||||
|     const char* s1 = addStringToPool(&pool, "hello world"); | ||||
|     const char* s2 = addStringToPool(&pool, "hello"); | ||||
|     const char* s1 = addStringToPool(pool, "hello world"); | ||||
|     const char* s2 = addStringToPool(pool, "hello"); | ||||
|  | ||||
|     REQUIRE(s2 != s1); | ||||
|     REQUIRE(pool.size() == 12 + 6); | ||||
|   } | ||||
|  | ||||
|   SECTION("Don't overrun") { | ||||
|     const char* s1 = addStringToPool(&pool, "hello world"); | ||||
|     const char* s2 = addStringToPool(&pool, "wor"); | ||||
|     const char* s1 = addStringToPool(pool, "hello world"); | ||||
|     const char* s2 = addStringToPool(pool, "wor"); | ||||
|  | ||||
|     REQUIRE(s2 != s1); | ||||
|     REQUIRE(pool.size() == 12 + 4); | ||||
|   | ||||
| @@ -12,8 +12,8 @@ using namespace ARDUINOJSON_NAMESPACE; | ||||
| static void testCodepoint(uint32_t codepoint, std::string expected) { | ||||
|   char buffer[4096]; | ||||
|   MemoryPool pool(buffer, 4096); | ||||
|   StringCopier str; | ||||
|   str.startString(&pool); | ||||
|   StringCopier str(pool); | ||||
|   str.startString(); | ||||
|  | ||||
|   CAPTURE(codepoint); | ||||
|   Utf8::encodeCodepoint(codepoint, str); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user