mirror of
				https://github.com/eledio-devices/thirdparty-ArduinoJson.git
				synced 2025-10-31 08:42:39 +01:00 
			
		
		
		
	Refactored StringBuilder into StringStorage
This commit is contained in:
		| @@ -525,7 +525,7 @@ TEST_CASE("Filtering") { | ||||
|       10, | ||||
|       DeserializationError::InvalidInput, | ||||
|       "{}",  | ||||
|       JSON_OBJECT_SIZE(0) + 8 | ||||
|       JSON_OBJECT_SIZE(0) | ||||
|     }, | ||||
|     { | ||||
|       // incomplete comment after key | ||||
| @@ -534,7 +534,7 @@ TEST_CASE("Filtering") { | ||||
|       10, | ||||
|       DeserializationError::IncompleteInput, | ||||
|       "{}",  | ||||
|       JSON_OBJECT_SIZE(0) + 8 | ||||
|       JSON_OBJECT_SIZE(0) | ||||
|     }, | ||||
|     { | ||||
|       // invalid comment after colon | ||||
| @@ -730,20 +730,3 @@ TEST_CASE("Overloads") { | ||||
|   } | ||||
| #endif | ||||
| } | ||||
|  | ||||
| TEST_CASE("StringMover::reclaim()") { | ||||
|   StaticJsonDocument<200> filter; | ||||
|   filter["a"] = true; | ||||
|   filter["c"] = true; | ||||
|   char input[] = "{\"a\":1,\"b\":2,\"c\":1}"; | ||||
|  | ||||
|   StaticJsonDocument<200> doc; | ||||
|   deserializeJson(doc, input, DeserializationOption::Filter(filter)); | ||||
|  | ||||
|   REQUIRE(doc.as<std::string>() == "{\"a\":1,\"c\":1}"); | ||||
|  | ||||
|   CHECK(input[0] == 'a'); | ||||
|   CHECK(input[1] == 0); | ||||
|   CHECK(input[2] == 'c'); | ||||
|   CHECK(input[3] == 0); | ||||
| } | ||||
|   | ||||
| @@ -7,7 +7,7 @@ add_executable(MemoryPoolTests | ||||
| 	allocString.cpp | ||||
| 	clear.cpp | ||||
| 	size.cpp | ||||
| 	StringBuilder.cpp | ||||
| 	StringCopier.cpp | ||||
| ) | ||||
|  | ||||
| add_test(MemoryPool MemoryPoolTests) | ||||
|   | ||||
| @@ -2,40 +2,44 @@ | ||||
| // Copyright Benoit Blanchon 2014-2020
 | ||||
| // MIT License
 | ||||
| 
 | ||||
| #include <ArduinoJson/Memory/MemoryPool.hpp> | ||||
| #include <ArduinoJson/Memory/StringBuilder.hpp> | ||||
| #include <ArduinoJson/StringStorage/StringCopier.hpp> | ||||
| #include <catch.hpp> | ||||
| 
 | ||||
| using namespace ARDUINOJSON_NAMESPACE; | ||||
| 
 | ||||
| TEST_CASE("StringBuilder") { | ||||
| TEST_CASE("StringCopier") { | ||||
|   char buffer[4096]; | ||||
| 
 | ||||
|   SECTION("Works when buffer is big enough") { | ||||
|     MemoryPool pool(buffer, addPadding(JSON_STRING_SIZE(6))); | ||||
|     StringCopier str; | ||||
| 
 | ||||
|     StringBuilder str(&pool); | ||||
|     str.startString(&pool); | ||||
|     str.append("hello"); | ||||
|     str.append('\0'); | ||||
| 
 | ||||
|     REQUIRE(str.complete() == std::string("hello")); | ||||
|     REQUIRE(str.isValid() == true); | ||||
|     REQUIRE(str.c_str() == std::string("hello")); | ||||
|   } | ||||
| 
 | ||||
|   SECTION("Returns null when too small") { | ||||
|     MemoryPool pool(buffer, sizeof(void*)); | ||||
|     StringCopier str; | ||||
| 
 | ||||
|     StringBuilder str(&pool); | ||||
|     str.startString(&pool); | ||||
|     str.append("hello world!"); | ||||
| 
 | ||||
|     REQUIRE(str.complete() == 0); | ||||
|     REQUIRE(str.isValid() == false); | ||||
|   } | ||||
| 
 | ||||
|   SECTION("Increases size of memory pool") { | ||||
|     MemoryPool pool(buffer, addPadding(JSON_STRING_SIZE(6))); | ||||
|     StringCopier str; | ||||
| 
 | ||||
|     StringBuilder str(&pool); | ||||
|     str.startString(&pool); | ||||
|     str.append('h'); | ||||
|     str.complete(); | ||||
|     str.commit(&pool); | ||||
| 
 | ||||
|     REQUIRE(JSON_STRING_SIZE(1) == pool.size()); | ||||
|     REQUIRE(1 == pool.size()); | ||||
|   } | ||||
| } | ||||
| @@ -22,11 +22,6 @@ TEST_CASE("MemoryPool::size()") { | ||||
|     REQUIRE(0 == pool.size()); | ||||
|   } | ||||
|  | ||||
|   SECTION("size() == capacity() after allocExpandableString()") { | ||||
|     pool.allocExpandableString(); | ||||
|     REQUIRE(pool.size() == pool.capacity()); | ||||
|   } | ||||
|  | ||||
|   SECTION("Decreases after freezeString()") { | ||||
|     StringSlot a = pool.allocExpandableString(); | ||||
|     pool.freezeString(a, 1); | ||||
|   | ||||
| @@ -12,12 +12,14 @@ using namespace ARDUINOJSON_NAMESPACE; | ||||
| static void testCodepoint(uint32_t codepoint, std::string expected) { | ||||
|   char buffer[4096]; | ||||
|   MemoryPool pool(buffer, 4096); | ||||
|   StringBuilder str(&pool); | ||||
|   StringCopier str; | ||||
|   str.startString(&pool); | ||||
|  | ||||
|   CAPTURE(codepoint); | ||||
|   Utf8::encodeCodepoint(codepoint, str); | ||||
|  | ||||
|   REQUIRE(str.complete() == expected); | ||||
|   str.append('\0'); | ||||
|   REQUIRE(str.c_str() == expected); | ||||
| } | ||||
|  | ||||
| TEST_CASE("Utf8::encodeCodepoint()") { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user