forked from bblanchon/ArduinoJson
Add a stub for BasicJsonDocument
This commit is contained in:
69
extras/tests/Deprecated/BasicJsonDocument.cpp
Normal file
69
extras/tests/Deprecated/BasicJsonDocument.cpp
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
// ArduinoJson - https://arduinojson.org
|
||||||
|
// Copyright © 2014-2023, Benoit BLANCHON
|
||||||
|
// MIT License
|
||||||
|
|
||||||
|
#include <ArduinoJson.h>
|
||||||
|
#include <catch.hpp>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
using ArduinoJson::detail::is_base_of;
|
||||||
|
|
||||||
|
static std::string allocatorLog;
|
||||||
|
|
||||||
|
struct CustomAllocator {
|
||||||
|
CustomAllocator() {
|
||||||
|
allocatorLog = "";
|
||||||
|
}
|
||||||
|
|
||||||
|
void* allocate(size_t n) {
|
||||||
|
allocatorLog += "A";
|
||||||
|
return malloc(n);
|
||||||
|
}
|
||||||
|
|
||||||
|
void deallocate(void* p) {
|
||||||
|
free(p);
|
||||||
|
allocatorLog += "D";
|
||||||
|
}
|
||||||
|
|
||||||
|
void* reallocate(void* p, size_t n) {
|
||||||
|
allocatorLog += "R";
|
||||||
|
return realloc(p, n);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
TEST_CASE("BasicJsonDocument") {
|
||||||
|
allocatorLog.clear();
|
||||||
|
|
||||||
|
SECTION("is a JsonDocument") {
|
||||||
|
REQUIRE(
|
||||||
|
is_base_of<JsonDocument, BasicJsonDocument<CustomAllocator>>::value ==
|
||||||
|
true);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("deserialize / serialize") {
|
||||||
|
BasicJsonDocument<CustomAllocator> doc(256);
|
||||||
|
deserializeJson(doc, "{\"hello\":\"world\"}");
|
||||||
|
REQUIRE(doc.as<std::string>() == "{\"hello\":\"world\"}");
|
||||||
|
doc.clear();
|
||||||
|
REQUIRE(allocatorLog == "ARAARDDD");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("copy") {
|
||||||
|
BasicJsonDocument<CustomAllocator> doc(256);
|
||||||
|
doc["hello"] = "world";
|
||||||
|
auto copy = doc;
|
||||||
|
REQUIRE(copy.as<std::string>() == "{\"hello\":\"world\"}");
|
||||||
|
REQUIRE(allocatorLog == "AA");
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("capacity") {
|
||||||
|
BasicJsonDocument<CustomAllocator> doc(256);
|
||||||
|
REQUIRE(doc.capacity() == 256);
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("garbageCollect()") {
|
||||||
|
BasicJsonDocument<CustomAllocator> doc(256);
|
||||||
|
doc.garbageCollect();
|
||||||
|
}
|
||||||
|
}
|
@ -15,6 +15,7 @@ if(MSVC)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_executable(DeprecatedTests
|
add_executable(DeprecatedTests
|
||||||
|
BasicJsonDocument.cpp
|
||||||
DynamicJsonDocument.cpp
|
DynamicJsonDocument.cpp
|
||||||
StaticJsonDocument.cpp
|
StaticJsonDocument.cpp
|
||||||
)
|
)
|
||||||
|
@ -42,6 +42,57 @@ class ARDUINOJSON_DEPRECATED("use JsonDocument instead") StaticJsonDocument
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
namespace detail {
|
||||||
|
template <typename TAllocator>
|
||||||
|
class AllocatorAdapter : public Allocator {
|
||||||
|
public:
|
||||||
|
AllocatorAdapter(const AllocatorAdapter&) = delete;
|
||||||
|
AllocatorAdapter& operator=(const AllocatorAdapter&) = delete;
|
||||||
|
|
||||||
|
void* allocate(size_t size) override {
|
||||||
|
return _allocator.allocate(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
void deallocate(void* ptr) override {
|
||||||
|
_allocator.deallocate(ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
void* reallocate(void* ptr, size_t new_size) override {
|
||||||
|
return _allocator.reallocate(ptr, new_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
static Allocator* instance() {
|
||||||
|
static AllocatorAdapter instance;
|
||||||
|
return &instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
AllocatorAdapter() = default;
|
||||||
|
~AllocatorAdapter() = default;
|
||||||
|
|
||||||
|
TAllocator _allocator;
|
||||||
|
};
|
||||||
|
} // namespace detail
|
||||||
|
|
||||||
|
// DEPRECATED: use JsonDocument instead
|
||||||
|
template <typename TAllocator>
|
||||||
|
class ARDUINOJSON_DEPRECATED("use JsonDocument instead") BasicJsonDocument
|
||||||
|
: public JsonDocument {
|
||||||
|
public:
|
||||||
|
BasicJsonDocument(size_t capacity)
|
||||||
|
: JsonDocument(detail::AllocatorAdapter<TAllocator>::instance()),
|
||||||
|
_capacity(capacity) {}
|
||||||
|
|
||||||
|
size_t capacity() const {
|
||||||
|
return _capacity;
|
||||||
|
}
|
||||||
|
|
||||||
|
void garbageCollect() {}
|
||||||
|
|
||||||
|
private:
|
||||||
|
size_t _capacity;
|
||||||
|
};
|
||||||
|
|
||||||
// DEPRECATED: use JsonDocument instead
|
// DEPRECATED: use JsonDocument instead
|
||||||
class ARDUINOJSON_DEPRECATED("use JsonDocument instead") DynamicJsonDocument
|
class ARDUINOJSON_DEPRECATED("use JsonDocument instead") DynamicJsonDocument
|
||||||
: public JsonDocument {
|
: public JsonDocument {
|
||||||
|
Reference in New Issue
Block a user