123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464 |
- // ArduinoJson - arduinojson.org
- // Copyright Benoit Blanchon 2014-2020
- // MIT License
- #include <ArduinoJson.h>
- #include <catch.hpp>
- template <typename T>
- void checkEquals(T a, T b) {
- DynamicJsonDocument doc(4096);
- JsonVariant variant = doc.to<JsonVariant>();
- variant.set(a);
- REQUIRE(b == variant);
- REQUIRE(variant == b);
- REQUIRE(b <= variant);
- REQUIRE(variant <= b);
- REQUIRE(b >= variant);
- REQUIRE(variant >= b);
- REQUIRE_FALSE(b != variant);
- REQUIRE_FALSE(variant != b);
- REQUIRE_FALSE(b > variant);
- REQUIRE_FALSE(variant > b);
- REQUIRE_FALSE(b < variant);
- REQUIRE_FALSE(variant < b);
- }
- template <typename T>
- void checkGreater(T a, T b) {
- DynamicJsonDocument doc(4096);
- JsonVariant variant = doc.to<JsonVariant>();
- variant.set(a);
- REQUIRE(variant > b);
- REQUIRE(b < variant);
- REQUIRE(variant != b);
- REQUIRE(b != variant);
- REQUIRE_FALSE(variant < b);
- REQUIRE_FALSE(b > variant);
- REQUIRE_FALSE(variant == b);
- REQUIRE_FALSE(b == variant);
- }
- template <typename T>
- void checkLower(T a, T b) {
- DynamicJsonDocument doc(4096);
- JsonVariant variant = doc.to<JsonVariant>();
- variant.set(a);
- REQUIRE(variant < b);
- REQUIRE(b > variant);
- REQUIRE(variant != b);
- REQUIRE(b != variant);
- REQUIRE_FALSE(variant > b);
- REQUIRE_FALSE(b < variant);
- REQUIRE_FALSE(variant == b);
- REQUIRE_FALSE(b == variant);
- }
- template <typename T>
- void checkComparisons(T low, T mid, T high) {
- checkEquals(mid, mid);
- checkGreater(mid, low);
- checkLower(mid, high);
- }
- TEST_CASE("JsonVariant comparisons") {
- static const char* null = 0;
- SECTION("Double") {
- checkComparisons<double>(123.44, 123.45, 123.46);
- }
- SECTION("Float") {
- checkComparisons<float>(123.44f, 123.45f, 123.46f);
- }
- SECTION("SChar") {
- checkComparisons<signed char>(122, 123, 124);
- }
- SECTION("SInt") {
- checkComparisons<signed int>(122, 123, 124);
- }
- SECTION("SLong") {
- checkComparisons<signed long>(122L, 123L, 124L);
- }
- SECTION("SShort") {
- checkComparisons<signed short>(122, 123, 124);
- }
- SECTION("UChar") {
- checkComparisons<unsigned char>(122, 123, 124);
- }
- SECTION("UInt") {
- checkComparisons<unsigned int>(122, 123, 124);
- }
- SECTION("ULong") {
- checkComparisons<unsigned long>(122L, 123L, 124L);
- }
- SECTION("UShort") {
- checkComparisons<unsigned short>(122, 123, 124);
- }
- SECTION("null") {
- DynamicJsonDocument doc(4096);
- JsonVariant variant = doc.to<JsonVariant>();
- variant.set(null);
- REQUIRE(variant == variant);
- REQUIRE_FALSE(variant != variant);
- REQUIRE(variant == null);
- REQUIRE_FALSE(variant != null);
- REQUIRE(variant != "null");
- REQUIRE_FALSE(variant == "null");
- }
- SECTION("StringLiteral") {
- DynamicJsonDocument doc(4096);
- deserializeJson(doc, "\"hello\"");
- JsonVariant variant = doc.as<JsonVariant>();
- REQUIRE(variant == variant);
- REQUIRE_FALSE(variant != variant);
- REQUIRE(variant == "hello");
- REQUIRE_FALSE(variant != "hello");
- REQUIRE(variant != "world");
- REQUIRE_FALSE(variant == "world");
- REQUIRE(variant != null);
- REQUIRE_FALSE(variant == null);
- REQUIRE("hello" == variant);
- REQUIRE_FALSE("hello" != variant);
- REQUIRE("world" != variant);
- REQUIRE_FALSE("world" == variant);
- REQUIRE(null != variant);
- REQUIRE_FALSE(null == variant);
- }
- SECTION("String") {
- DynamicJsonDocument doc(4096);
- JsonVariant variant = doc.to<JsonVariant>();
- variant.set("hello");
- REQUIRE(variant == variant);
- REQUIRE_FALSE(variant != variant);
- REQUIRE(variant == std::string("hello"));
- REQUIRE_FALSE(variant != std::string("hello"));
- REQUIRE(variant != std::string("world"));
- REQUIRE_FALSE(variant == std::string("world"));
- REQUIRE(variant != null);
- REQUIRE_FALSE(variant == null);
- REQUIRE(std::string("hello") == variant);
- REQUIRE_FALSE(std::string("hello") != variant);
- REQUIRE(std::string("world") != variant);
- REQUIRE_FALSE(std::string("world") == variant);
- REQUIRE(null != variant);
- REQUIRE_FALSE(null == variant);
- }
- #ifdef HAS_VARIABLE_LENGTH_ARRAY
- SECTION("VLA equals") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc(4096);
- JsonVariant variant = doc.to<JsonVariant>();
- variant.set("hello");
- REQUIRE((vla == variant));
- REQUIRE((variant == vla));
- REQUIRE_FALSE((vla != variant));
- REQUIRE_FALSE((variant != vla));
- }
- SECTION("VLA differs") {
- int i = 16;
- char vla[i];
- strcpy(vla, "hello");
- DynamicJsonDocument doc(4096);
- JsonVariant variant = doc.to<JsonVariant>();
- variant.set("world");
- REQUIRE((vla != variant));
- REQUIRE((variant != vla));
- REQUIRE_FALSE((vla == variant));
- REQUIRE_FALSE((variant == vla));
- }
- #endif
- DynamicJsonDocument doc1(4096), doc2(4096), doc3(4096);
- JsonVariant variant1 = doc1.to<JsonVariant>();
- JsonVariant variant2 = doc2.to<JsonVariant>();
- JsonVariant variant3 = doc3.to<JsonVariant>();
- SECTION("Variants containing integers") {
- variant1.set(42);
- variant2.set(42);
- variant3.set(666);
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant1 != variant3);
- REQUIRE_FALSE(variant1 == variant3);
- }
- SECTION("Variants containing linked strings") {
- // create two identical strings at different addresses
- char hello1[] = "hello";
- char hello2[] = "hello";
- REQUIRE(hello1 != hello2);
- variant1.set(hello1);
- variant2.set(hello2);
- variant3.set("world");
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant1 != variant3);
- REQUIRE_FALSE(variant1 == variant3);
- }
- SECTION("Variants containing owned strings") {
- variant1.set(std::string("hello"));
- variant2.set(std::string("hello"));
- variant3.set(std::string("world"));
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant1 != variant3);
- REQUIRE_FALSE(variant1 == variant3);
- }
- SECTION("Variants containing linked raws") {
- // create two identical strings at different addresses
- char hello1[] = "hello";
- char hello2[] = "hello";
- REQUIRE(hello1 != hello2);
- variant1.set(serialized(hello1));
- variant2.set(serialized(hello2));
- variant3.set(serialized("world"));
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant1 != variant3);
- REQUIRE_FALSE(variant1 == variant3);
- }
- SECTION("Variants containing owned raws") {
- variant1.set(serialized(std::string("hello")));
- variant2.set(serialized(std::string("hello")));
- variant3.set(serialized(std::string("world")));
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant1 != variant3);
- REQUIRE_FALSE(variant1 == variant3);
- }
- SECTION("Variants containing mixed strings (issue #1051)") {
- variant1.set("hello");
- variant2.set(std::string("hello"));
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant2 == variant1);
- REQUIRE_FALSE(variant2 != variant1);
- }
- SECTION("Variants containing double") {
- variant1.set(42.0);
- variant2.set(42.0);
- variant3.set(666.0);
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant1 != variant3);
- REQUIRE_FALSE(variant1 == variant3);
- }
- SECTION("BoolInVariant") {
- variant1.set(true);
- variant2.set(true);
- variant3.set(false);
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant1 != variant3);
- REQUIRE_FALSE(variant1 == variant3);
- }
- SECTION("ArrayInVariant") {
- JsonArray array1 = variant1.to<JsonArray>();
- JsonArray array2 = variant2.to<JsonArray>();
- array1.add(42);
- array2.add(42);
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant1 != variant3);
- REQUIRE_FALSE(variant1 == variant3);
- }
- SECTION("ObjectInVariant") {
- JsonObject obj1 = variant1.to<JsonObject>();
- JsonObject obj2 = variant2.to<JsonObject>();
- obj1["hello"] = "world";
- obj2["hello"] = "world";
- REQUIRE(variant1 == variant2);
- REQUIRE_FALSE(variant1 != variant2);
- REQUIRE(variant1 != variant3);
- REQUIRE_FALSE(variant1 == variant3);
- }
- }
- class VariantComparisionFixture {
- private:
- StaticJsonDocument<256> doc;
- JsonVariant variant;
- public:
- VariantComparisionFixture() : variant(doc.to<JsonVariant>()) {}
- protected:
- template <typename T>
- void setValue(const T& value) {
- variant.set(value);
- }
- template <typename T>
- void assertEqualsTo(const T& value) {
- REQUIRE(variant == value);
- REQUIRE(value == variant);
- REQUIRE_FALSE(variant != value);
- REQUIRE_FALSE(value != variant);
- }
- template <typename T>
- void assertDiffersFrom(const T& value) {
- REQUIRE(variant != value);
- REQUIRE(value != variant);
- REQUIRE_FALSE(variant == value);
- REQUIRE_FALSE(value == variant);
- }
- template <typename T>
- void assertGreaterThan(const T& value) {
- REQUIRE((variant > value));
- REQUIRE((variant >= value));
- REQUIRE(value < variant);
- REQUIRE(value <= variant);
- REQUIRE_FALSE((variant < value));
- REQUIRE_FALSE((variant <= value));
- REQUIRE_FALSE(value > variant);
- REQUIRE_FALSE(value >= variant);
- }
- template <typename T>
- void assertLowerThan(const T& value) {
- REQUIRE(variant < value);
- REQUIRE(variant <= value);
- REQUIRE(value > variant);
- REQUIRE(value >= variant);
- REQUIRE_FALSE(variant > value);
- REQUIRE_FALSE(variant >= value);
- REQUIRE_FALSE(value < variant);
- REQUIRE_FALSE(value <= variant);
- }
- };
- TEST_CASE_METHOD(VariantComparisionFixture,
- "Compare variant with another type") {
- SECTION("null") {
- assertDiffersFrom(3);
- assertDiffersFrom("world");
- }
- SECTION("string") {
- setValue("hello");
- assertEqualsTo("hello");
- assertDiffersFrom(3);
- assertDiffersFrom("world");
- assertGreaterThan("helln");
- assertLowerThan("hellp");
- }
- SECTION("positive integer") {
- setValue(42);
- assertEqualsTo(42);
- assertDiffersFrom(43);
- assertGreaterThan(41);
- assertLowerThan(43);
- assertDiffersFrom("world");
- }
- SECTION("negative integer") {
- setValue(-42);
- assertEqualsTo(-42);
- assertDiffersFrom(42);
- assertGreaterThan(-43);
- assertLowerThan(-41);
- assertDiffersFrom("world");
- }
- SECTION("double") {
- setValue(42.0);
- assertEqualsTo(42.0);
- assertDiffersFrom(42.1);
- assertGreaterThan(41.0);
- assertLowerThan(43.0);
- assertDiffersFrom("42.0");
- }
- SECTION("true") {
- setValue(true);
- assertEqualsTo(true);
- assertDiffersFrom(false);
- assertDiffersFrom(1);
- assertDiffersFrom("true");
- assertDiffersFrom(1.0);
- assertGreaterThan(false);
- }
- }
|