| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- #include <gtest/gtest.h>
- #include <StaticJsonBuffer.h>
- #include <JsonValue.h>
- 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"]);
- }
|