| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- #include <gtest/gtest.h>
- #include <ArduinoJson/StaticJsonBuffer.hpp>
- #include <ArduinoJson/JsonValue.hpp>
- using namespace ArduinoJson;
- class JsonObject_Container_Tests : public ::testing::Test {
- protected:
- virtual void SetUp() { object = json.createObject(); }
- StaticJsonBuffer<42> json;
- JsonObject object;
- };
- TEST_F(JsonObject_Container_Tests, InitialSizeIsZero) {
- EXPECT_EQ(0, object.size());
- }
- TEST_F(JsonObject_Container_Tests, Grow_WhenValuesAreAdded) {
- object["hello"];
- EXPECT_EQ(1, object.size());
- object["world"];
- EXPECT_EQ(2, object.size());
- }
- TEST_F(JsonObject_Container_Tests, DoNotGrow_WhenSameValueIsAdded) {
- object["hello"];
- EXPECT_EQ(1, object.size());
- object["hello"];
- EXPECT_EQ(1, object.size());
- }
- TEST_F(JsonObject_Container_Tests, Shrink_WhenValuesAreRemoved) {
- object["hello"];
- object["world"];
- object.remove("hello");
- EXPECT_EQ(1, object.size());
- object.remove("world");
- EXPECT_EQ(0, object.size());
- }
- TEST_F(JsonObject_Container_Tests,
- DoNotShrink_WhenRemoveIsCalledWithAWrongKey) {
- object["hello"];
- object["world"];
- object.remove(":-P");
- EXPECT_EQ(2, object.size());
- }
- TEST_F(JsonObject_Container_Tests, CanStoreIntegers) {
- object["hello"] = 123;
- object["world"] = 456;
- EXPECT_EQ(123, (int)object["hello"]);
- EXPECT_EQ(456, (int)object["world"]);
- }
- TEST_F(JsonObject_Container_Tests, CanStoreDoubles) {
- object["hello"] = 123.45;
- object["world"] = 456.78;
- EXPECT_EQ(123.45, (double)object["hello"]);
- EXPECT_EQ(456.78, (double)object["world"]);
- }
- TEST_F(JsonObject_Container_Tests, CanStoreBooleans) {
- object["hello"] = true;
- object["world"] = false;
- EXPECT_TRUE((bool)object["hello"]);
- EXPECT_FALSE((bool)object["world"]);
- }
- TEST_F(JsonObject_Container_Tests, CanStoreStrings) {
- object["hello"] = "h3110";
- object["world"] = "w0r1d";
- EXPECT_STREQ("h3110", (const char *)object["hello"]);
- EXPECT_STREQ("w0r1d", (const char *)object["world"]);
- }
- TEST_F(JsonObject_Container_Tests, CanStoreInnerArrays) {
- JsonArray innerarray1 = json.createArray();
- JsonArray innerarray2 = json.createArray();
- object["hello"] = innerarray1;
- object["world"] = innerarray2;
- EXPECT_EQ(innerarray1, (JsonArray)object["hello"]);
- EXPECT_EQ(innerarray2, (JsonArray)object["world"]);
- }
- TEST_F(JsonObject_Container_Tests, CanStoreInnerObjects) {
- JsonObject innerObject1 = json.createObject();
- JsonObject innerObject2 = json.createObject();
- object["hello"] = innerObject1;
- object["world"] = innerObject2;
- EXPECT_EQ(innerObject1, (JsonObject)object["hello"]);
- EXPECT_EQ(innerObject2, (JsonObject)object["world"]);
- }
|