|
@@ -40,120 +40,275 @@ TEST(Element, type) {
|
|
|
EXPECT_EQ(bool_el.getType(), Element::boolean);
|
|
|
StringElement str_el = StringElement("foo");
|
|
|
EXPECT_EQ(str_el.getType(), Element::string);
|
|
|
- std::vector<ElementPtr> v;
|
|
|
- ListElement list_el = ListElement(v);
|
|
|
+ ListElement list_el = ListElement();
|
|
|
EXPECT_EQ(list_el.getType(), Element::list);
|
|
|
- std::map<std::string, ElementPtr> m;
|
|
|
- MapElement map_el = MapElement(m);
|
|
|
+ MapElement map_el = MapElement();
|
|
|
EXPECT_EQ(map_el.getType(), Element::map);
|
|
|
+
|
|
|
}
|
|
|
|
|
|
-TEST(Element, from_and_to_str) {
|
|
|
- // this test checks whether the str() method returns the same
|
|
|
- // string that was used for creation
|
|
|
+TEST(Element, TypeNameConversion) {
|
|
|
+ EXPECT_EQ(Element::integer, Element::nameToType("integer"));
|
|
|
+ EXPECT_EQ(Element::real, Element::nameToType("real"));
|
|
|
+ EXPECT_EQ(Element::boolean, Element::nameToType("boolean"));
|
|
|
+ EXPECT_EQ(Element::string, Element::nameToType("string"));
|
|
|
+ EXPECT_EQ(Element::list, Element::nameToType("list"));
|
|
|
+ EXPECT_EQ(Element::map, Element::nameToType("map"));
|
|
|
+ EXPECT_EQ(Element::null, Element::nameToType("null"));
|
|
|
+ EXPECT_EQ(Element::any, Element::nameToType("any"));
|
|
|
+ EXPECT_THROW(Element::nameToType("somethingunknown"), TypeError);
|
|
|
+
|
|
|
+ EXPECT_EQ("integer", Element::typeToName(Element::integer));
|
|
|
+ EXPECT_EQ("real", Element::typeToName(Element::real));
|
|
|
+ EXPECT_EQ("boolean", Element::typeToName(Element::boolean));
|
|
|
+ EXPECT_EQ("string", Element::typeToName(Element::string));
|
|
|
+ EXPECT_EQ("list", Element::typeToName(Element::list));
|
|
|
+ EXPECT_EQ("map", Element::typeToName(Element::map));
|
|
|
+ EXPECT_EQ("null", Element::typeToName(Element::null));
|
|
|
+ EXPECT_EQ("any", Element::typeToName(Element::any));
|
|
|
+ EXPECT_EQ("unknown", Element::typeToName((Element::types)123));
|
|
|
+}
|
|
|
+
|
|
|
+TEST(Element, from_and_to_json) {
|
|
|
+ // a set of inputs that are the same when converted to json and
|
|
|
+ // back to a string (tests for inputs that have equivalent, but
|
|
|
+ // different string representations when converted back are below)
|
|
|
ElementPtr el;
|
|
|
std::vector<std::string> sv;
|
|
|
|
|
|
sv.push_back("12");
|
|
|
sv.push_back("1.1");
|
|
|
- sv.push_back("True");
|
|
|
- sv.push_back("False");
|
|
|
+ sv.push_back("true");
|
|
|
+ sv.push_back("false");
|
|
|
sv.push_back("\"asdf\"");
|
|
|
+ sv.push_back("null");
|
|
|
sv.push_back("[ 1, 2, 3, 4 ]");
|
|
|
- sv.push_back("{\"name\": \"foo\", \"value\": 47806}");
|
|
|
- sv.push_back("[ {\"a\": 1, \"b\": \"c\"}, {\"a\": 2, \"b\": \"d\"} ]");
|
|
|
-
|
|
|
+ sv.push_back("{ \"name\": \"foo\", \"value\": 47806 }");
|
|
|
+ sv.push_back("[ { \"a\": 1, \"b\": \"c\" }, { \"a\": 2, \"b\": \"d\" } ]");
|
|
|
+ sv.push_back("8.23");
|
|
|
+ sv.push_back("123.456");
|
|
|
+ sv.push_back("null");
|
|
|
+ sv.push_back("-1");
|
|
|
+ sv.push_back("-1.234");
|
|
|
+ sv.push_back("-123.456");
|
|
|
+
|
|
|
BOOST_FOREACH(std::string s, sv) {
|
|
|
- // also test << operator, which uses Element::str()
|
|
|
+ // test << operator, which uses Element::str()
|
|
|
std::ostringstream stream;
|
|
|
- el = Element::createFromString(s);
|
|
|
+ el = Element::fromJSON(s);
|
|
|
stream << el;
|
|
|
EXPECT_EQ(stream.str(), s);
|
|
|
+
|
|
|
+ // test toWire(ostream), which should also be the same now
|
|
|
+ std::ostringstream wire_stream;
|
|
|
+ el->toWire(wire_stream);
|
|
|
+ EXPECT_EQ(wire_stream.str(), s);
|
|
|
}
|
|
|
|
|
|
// some parse errors
|
|
|
try {
|
|
|
- Element::createFromString("{1}");
|
|
|
- } catch (isc::data::ParseError pe) {
|
|
|
+ Element::fromJSON("{1}");
|
|
|
+ } catch (isc::data::JSONError pe) {
|
|
|
std::string s = std::string(pe.what());
|
|
|
EXPECT_EQ(s, "String expected in <string>:1:3");
|
|
|
}
|
|
|
|
|
|
sv.clear();
|
|
|
sv.push_back("{1}");
|
|
|
- //ElementPtr ep = Element::createFromString("\"aaa\nbbb\"err");
|
|
|
+ //ElementPtr ep = Element::fromJSON("\"aaa\nbbb\"err");
|
|
|
//std::cout << ep << std::endl;
|
|
|
sv.push_back("\n\nTru");
|
|
|
sv.push_back("{ \n \"aaa\nbbb\"err:");
|
|
|
sv.push_back("{ \t\n \"aaa\nbbb\"\t\n\n:\n True, \"\\\"");
|
|
|
sv.push_back("{ \"a\": None}");
|
|
|
sv.push_back("");
|
|
|
+ sv.push_back("nul");
|
|
|
BOOST_FOREACH(std::string s, sv) {
|
|
|
|
|
|
- EXPECT_THROW(el = Element::createFromString(s), isc::data::ParseError);
|
|
|
+ EXPECT_THROW(el = Element::fromJSON(s), isc::data::JSONError);
|
|
|
}
|
|
|
|
|
|
+ // some json specific format tests, here the str() output is
|
|
|
+ // different from the string input
|
|
|
+ EXPECT_EQ("100", Element::fromJSON("+100")->str());
|
|
|
+ EXPECT_EQ("100", Element::fromJSON("1e2")->str());
|
|
|
+ EXPECT_EQ("100", Element::fromJSON("+1e2")->str());
|
|
|
+ EXPECT_EQ("-100", Element::fromJSON("-1e2")->str());
|
|
|
+ EXPECT_EQ("0.01", Element::fromJSON("1e-2")->str());
|
|
|
+ EXPECT_EQ("0.01", Element::fromJSON(".01")->str());
|
|
|
+ EXPECT_EQ("-0.01", Element::fromJSON("-1e-2")->str());
|
|
|
+ EXPECT_EQ("1.2", Element::fromJSON("1.2")->str());
|
|
|
+ EXPECT_EQ("1", Element::fromJSON("1.0")->str());
|
|
|
+ EXPECT_EQ("120", Element::fromJSON("1.2e2")->str());
|
|
|
+ EXPECT_EQ("100", Element::fromJSON("1.0e2")->str());
|
|
|
+ EXPECT_EQ("100", Element::fromJSON("1.0E2")->str());
|
|
|
+ EXPECT_EQ("0.01", Element::fromJSON("1.0e-2")->str());
|
|
|
+ EXPECT_EQ("0.012", Element::fromJSON("1.2e-2")->str());
|
|
|
+ EXPECT_EQ("0.012", Element::fromJSON("1.2E-2")->str());
|
|
|
+ EXPECT_EQ("null", Element::fromJSON("Null")->str());
|
|
|
+ EXPECT_EQ("null", Element::fromJSON("NULL")->str());
|
|
|
+ EXPECT_EQ("false", Element::fromJSON("False")->str());
|
|
|
+ EXPECT_EQ("false", Element::fromJSON("FALSE")->str());
|
|
|
+ EXPECT_EQ("true", Element::fromJSON("True")->str());
|
|
|
+ EXPECT_EQ("true", Element::fromJSON("TRUE")->str());
|
|
|
+
|
|
|
+ // number overflows
|
|
|
+ EXPECT_THROW(Element::fromJSON("12345678901234567890")->str(), JSONError);
|
|
|
+ EXPECT_THROW(Element::fromJSON("1.1e12345678901234567890")->str(), JSONError);
|
|
|
+ EXPECT_THROW(Element::fromJSON("-1.1e12345678901234567890")->str(), JSONError);
|
|
|
+ EXPECT_THROW(Element::fromJSON("1e12345678901234567890")->str(), JSONError);
|
|
|
+ EXPECT_THROW(Element::fromJSON("1e50000")->str(), JSONError);
|
|
|
+
|
|
|
}
|
|
|
|
|
|
TEST(Element, create_and_value_throws) {
|
|
|
// this test checks whether elements throw exceptions if the
|
|
|
// incorrect type is requested
|
|
|
ElementPtr el;
|
|
|
+ long int i;
|
|
|
+ double d;
|
|
|
+ bool b;
|
|
|
+ std::string s("asdf");
|
|
|
+ std::vector<ElementPtr> v;
|
|
|
+ std::map<std::string, ElementPtr> m;
|
|
|
+
|
|
|
|
|
|
el = Element::create(1);
|
|
|
+ EXPECT_NO_THROW(el->intValue());
|
|
|
EXPECT_THROW(el->doubleValue(), TypeError);
|
|
|
EXPECT_THROW(el->boolValue(), TypeError);
|
|
|
EXPECT_THROW(el->stringValue(), TypeError);
|
|
|
EXPECT_THROW(el->listValue(), TypeError);
|
|
|
EXPECT_THROW(el->mapValue(), TypeError);
|
|
|
+ EXPECT_TRUE(el->getValue(i));
|
|
|
+ EXPECT_FALSE(el->getValue(d));
|
|
|
+ EXPECT_FALSE(el->getValue(b));
|
|
|
+ EXPECT_FALSE(el->getValue(s));
|
|
|
+ EXPECT_FALSE(el->getValue(v));
|
|
|
+ EXPECT_FALSE(el->getValue(m));
|
|
|
+ EXPECT_EQ(i, 1);
|
|
|
+ i = 2;
|
|
|
+ EXPECT_TRUE(el->setValue(i));
|
|
|
+ EXPECT_EQ(2, el->intValue());
|
|
|
+ EXPECT_FALSE(el->setValue(d));
|
|
|
+ EXPECT_FALSE(el->setValue(b));
|
|
|
+ EXPECT_FALSE(el->setValue(s));
|
|
|
+ EXPECT_FALSE(el->setValue(v));
|
|
|
+ EXPECT_FALSE(el->setValue(m));
|
|
|
+ EXPECT_THROW(el->get(1), TypeError);
|
|
|
+ EXPECT_THROW(el->set(1, el), TypeError);
|
|
|
+ EXPECT_THROW(el->add(el), TypeError);
|
|
|
+ EXPECT_THROW(el->remove(1), TypeError);
|
|
|
+ EXPECT_THROW(el->size(), TypeError);
|
|
|
+ EXPECT_THROW(el->get("foo"), TypeError);
|
|
|
+ EXPECT_THROW(el->set("foo", el), TypeError);
|
|
|
+ EXPECT_THROW(el->remove("foo"), TypeError);
|
|
|
+ EXPECT_THROW(el->contains("foo"), TypeError);
|
|
|
+ ElementPtr tmp;
|
|
|
+ EXPECT_FALSE(el->find("foo", tmp));
|
|
|
+
|
|
|
|
|
|
el = Element::create(1.1);
|
|
|
EXPECT_THROW(el->intValue(), TypeError);
|
|
|
+ EXPECT_NO_THROW(el->doubleValue());
|
|
|
EXPECT_THROW(el->boolValue(), TypeError);
|
|
|
EXPECT_THROW(el->stringValue(), TypeError);
|
|
|
EXPECT_THROW(el->listValue(), TypeError);
|
|
|
EXPECT_THROW(el->mapValue(), TypeError);
|
|
|
+ EXPECT_FALSE(el->getValue(i));
|
|
|
+ EXPECT_TRUE(el->getValue(d));
|
|
|
+ EXPECT_FALSE(el->getValue(b));
|
|
|
+ EXPECT_FALSE(el->getValue(s));
|
|
|
+ EXPECT_FALSE(el->getValue(v));
|
|
|
+ EXPECT_FALSE(el->getValue(m));
|
|
|
+ EXPECT_EQ(d, 1.1);
|
|
|
+ d = 2.2;
|
|
|
+ EXPECT_TRUE(el->setValue(d));
|
|
|
+ EXPECT_EQ(2.2, el->doubleValue());
|
|
|
+ EXPECT_FALSE(el->setValue(i));
|
|
|
+ EXPECT_FALSE(el->setValue(b));
|
|
|
+ EXPECT_FALSE(el->setValue(s));
|
|
|
+ EXPECT_FALSE(el->setValue(v));
|
|
|
+ EXPECT_FALSE(el->setValue(m));
|
|
|
|
|
|
el = Element::create(true);
|
|
|
EXPECT_THROW(el->intValue(), TypeError);
|
|
|
EXPECT_THROW(el->doubleValue(), TypeError);
|
|
|
+ EXPECT_NO_THROW(el->boolValue());
|
|
|
EXPECT_THROW(el->stringValue(), TypeError);
|
|
|
EXPECT_THROW(el->listValue(), TypeError);
|
|
|
EXPECT_THROW(el->mapValue(), TypeError);
|
|
|
+ EXPECT_FALSE(el->getValue(i));
|
|
|
+ EXPECT_FALSE(el->getValue(d));
|
|
|
+ EXPECT_TRUE(el->getValue(b));
|
|
|
+ EXPECT_FALSE(el->getValue(s));
|
|
|
+ EXPECT_FALSE(el->getValue(v));
|
|
|
+ EXPECT_FALSE(el->getValue(m));
|
|
|
+ EXPECT_EQ(b, true);
|
|
|
+ b = false;
|
|
|
+ EXPECT_TRUE(el->setValue(b));
|
|
|
+ EXPECT_EQ(false, el->boolValue());
|
|
|
|
|
|
el = Element::create("foo");
|
|
|
EXPECT_THROW(el->intValue(), TypeError);
|
|
|
EXPECT_THROW(el->doubleValue(), TypeError);
|
|
|
EXPECT_THROW(el->boolValue(), TypeError);
|
|
|
+ EXPECT_NO_THROW(el->stringValue());
|
|
|
EXPECT_THROW(el->listValue(), TypeError);
|
|
|
EXPECT_THROW(el->mapValue(), TypeError);
|
|
|
-
|
|
|
- std::vector<ElementPtr> v;
|
|
|
- el = Element::create(v);
|
|
|
+ EXPECT_FALSE(el->getValue(i));
|
|
|
+ EXPECT_FALSE(el->getValue(d));
|
|
|
+ EXPECT_FALSE(el->getValue(b));
|
|
|
+ EXPECT_TRUE(el->getValue(s));
|
|
|
+ EXPECT_FALSE(el->getValue(v));
|
|
|
+ EXPECT_FALSE(el->getValue(m));
|
|
|
+ EXPECT_EQ(s, "foo");
|
|
|
+ s = "bar";
|
|
|
+ EXPECT_TRUE(el->setValue(s));
|
|
|
+ EXPECT_EQ("bar", el->stringValue());
|
|
|
+
|
|
|
+ el = Element::createList();
|
|
|
EXPECT_THROW(el->intValue(), TypeError);
|
|
|
EXPECT_THROW(el->doubleValue(), TypeError);
|
|
|
EXPECT_THROW(el->boolValue(), TypeError);
|
|
|
EXPECT_THROW(el->stringValue(), TypeError);
|
|
|
+ EXPECT_NO_THROW(el->listValue());
|
|
|
EXPECT_THROW(el->mapValue(), TypeError);
|
|
|
-
|
|
|
- std::map<std::string, ElementPtr> m;
|
|
|
- el = Element::create(m);
|
|
|
+ EXPECT_FALSE(el->getValue(i));
|
|
|
+ EXPECT_FALSE(el->getValue(d));
|
|
|
+ EXPECT_FALSE(el->getValue(b));
|
|
|
+ EXPECT_FALSE(el->getValue(s));
|
|
|
+ EXPECT_TRUE(el->getValue(v));
|
|
|
+ EXPECT_FALSE(el->getValue(m));
|
|
|
+ EXPECT_EQ("[ ]", el->str());
|
|
|
+ v.push_back(Element::create(1));
|
|
|
+ EXPECT_TRUE(el->setValue(v));
|
|
|
+ EXPECT_EQ("[ 1 ]", el->str());
|
|
|
+
|
|
|
+ el = Element::createMap();
|
|
|
EXPECT_THROW(el->intValue(), TypeError);
|
|
|
EXPECT_THROW(el->doubleValue(), TypeError);
|
|
|
EXPECT_THROW(el->boolValue(), TypeError);
|
|
|
EXPECT_THROW(el->stringValue(), TypeError);
|
|
|
EXPECT_THROW(el->listValue(), TypeError);
|
|
|
+ EXPECT_NO_THROW(el->mapValue());
|
|
|
+ EXPECT_FALSE(el->getValue(i));
|
|
|
+ EXPECT_FALSE(el->getValue(d));
|
|
|
+ EXPECT_FALSE(el->getValue(b));
|
|
|
+ EXPECT_FALSE(el->getValue(s));
|
|
|
+ EXPECT_FALSE(el->getValue(v));
|
|
|
+ EXPECT_TRUE(el->getValue(m));
|
|
|
|
|
|
}
|
|
|
|
|
|
TEST(Element, ListElement) {
|
|
|
// this function checks the specific functions for ListElements
|
|
|
- ElementPtr el = Element::createFromString("[ 1, \"bar\", 3 ]");
|
|
|
+ ElementPtr el = Element::fromJSON("[ 1, \"bar\", 3 ]");
|
|
|
EXPECT_EQ(el->get(0)->intValue(), 1);
|
|
|
EXPECT_EQ(el->get(1)->stringValue(), "bar");
|
|
|
EXPECT_EQ(el->get(2)->intValue(), 3);
|
|
|
|
|
|
- el->set(0, Element::createFromString("\"foo\""));
|
|
|
+ el->set(0, Element::fromJSON("\"foo\""));
|
|
|
EXPECT_EQ(el->get(0)->stringValue(), "foo");
|
|
|
|
|
|
el->add(Element::create(47806));
|
|
@@ -170,18 +325,9 @@ TEST(Element, ListElement) {
|
|
|
EXPECT_EQ(el->get(2)->intValue(), 32);
|
|
|
}
|
|
|
|
|
|
-namespace {
|
|
|
-const string long_maptag("0123456789abcdef1123456789abcdef2123456789abcdef"
|
|
|
- "3123456789abcdef4123456789abcdef5123456789abcdef"
|
|
|
- "6123456789abcdef7123456789abcdef8123456789abcdef"
|
|
|
- "9123456789abcdefa123456789abcdefb123456789abcdef"
|
|
|
- "c123456789abcdefd123456789abcdefe123456789abcdef"
|
|
|
- "f123456789abcdef");
|
|
|
-}
|
|
|
-
|
|
|
TEST(Element, MapElement) {
|
|
|
// this function checks the specific functions for ListElements
|
|
|
- ElementPtr el = Element::createFromString("{ \"name\": \"foo\", \"value1\": \"bar\", \"value2\": { \"number\": 42 } }");
|
|
|
+ ElementPtr el = Element::fromJSON("{ \"name\": \"foo\", \"value1\": \"bar\", \"value2\": { \"number\": 42 } }");
|
|
|
ElementPtr el2;
|
|
|
|
|
|
EXPECT_EQ(el->get("name")->stringValue(), "foo");
|
|
@@ -211,240 +357,241 @@ TEST(Element, MapElement) {
|
|
|
"9123456789abcdefa123456789abcdefb123456789abcdef"
|
|
|
"c123456789abcdefd123456789abcdefe123456789abcdef"
|
|
|
"f123456789abcde");
|
|
|
- std::map<std::string, ElementPtr> long_maptag_map;
|
|
|
|
|
|
EXPECT_EQ(255, long_maptag.length()); // check prerequisite
|
|
|
- el = Element::createFromString("{ \"" + long_maptag + "\": \"bar\"}");
|
|
|
+ el = Element::fromJSON("{ \"" + long_maptag + "\": \"bar\"}");
|
|
|
EXPECT_EQ("bar", el->find(long_maptag)->stringValue());
|
|
|
|
|
|
- long_maptag_map[long_maptag] = Element::create("bar");
|
|
|
- el = Element::create(long_maptag_map);
|
|
|
+ el = Element::createMap();
|
|
|
+ el->set(long_maptag, Element::create("bar"));
|
|
|
EXPECT_EQ("bar", el->find(long_maptag)->stringValue());
|
|
|
|
|
|
- // A one-byte longer tag should trigger an exception.
|
|
|
+ // A one-byte longer tag should still be allowed
|
|
|
long_maptag.push_back('f');
|
|
|
- EXPECT_THROW(Element::createFromString("{ \"" + long_maptag +
|
|
|
- "\": \"bar\"}"),
|
|
|
- ParseError);
|
|
|
-
|
|
|
- long_maptag_map[long_maptag] = Element::create("bar");
|
|
|
- EXPECT_THROW(Element::create(long_maptag_map), TypeError);
|
|
|
+ el = Element::fromJSON("{ \"" + long_maptag + "\": \"bar\"}");
|
|
|
+ el->set(long_maptag, Element::create("bar"));
|
|
|
+ EXPECT_EQ("bar", el->find(long_maptag)->stringValue());
|
|
|
|
|
|
}
|
|
|
|
|
|
TEST(Element, to_and_from_wire) {
|
|
|
- ElementPtr el, decoded_el;
|
|
|
- std::string wire;
|
|
|
- std::vector<std::string> sv;
|
|
|
- std::vector<std::string> sw;
|
|
|
- std::stringstream bigstring, bigstring2;
|
|
|
- std::stringstream bigwire, bigwire2;
|
|
|
-
|
|
|
- sv.push_back("{\"name\": \"foo\"}");
|
|
|
- sw.push_back("Skan\004name\050\003foo");
|
|
|
- sv.push_back("{\"value2\": {\"number\": 42}}");
|
|
|
- sw.push_back("Skan\006value2\042\013\006number\046\00242");
|
|
|
- sv.push_back("{\"bool\": False, \"bool2\": True, \"real\": 2.34, \"string\": \"foo\"}");
|
|
|
- sw.push_back("Skan\004bool\045\0010\005bool2\045\0011\004real\047\0042\05634\006string\050\003foo");
|
|
|
- sv.push_back("{\"list\": [ 1, 2, 3, 4 ]}");
|
|
|
- sw.push_back("Skan\004list\043\014\046\0011\046\0012\046\0013\046\0014");
|
|
|
-
|
|
|
- // some big ones
|
|
|
-
|
|
|
- bigstring << "{\"bigstring\": \"";
|
|
|
- bigwire << "Skan\011bigstring\030\001\001";
|
|
|
- for (size_t i = 0; i < 257; i++) {
|
|
|
- bigstring << "x";
|
|
|
- bigwire << "x";
|
|
|
- }
|
|
|
- bigstring << "\"}";
|
|
|
- sv.push_back(bigstring.str());
|
|
|
- sw.push_back(bigwire.str());
|
|
|
-
|
|
|
-
|
|
|
- bigstring2 << "{\"bigstring2\": \"";
|
|
|
- bigwire2 << "Skan\012bigstring2\010";
|
|
|
- bigwire2 << '\000' << '\001' << '\000' << '\001';
|
|
|
- for (size_t i = 0; i < 65537; i++) {
|
|
|
- bigstring2 << "x";
|
|
|
- bigwire2 << "x";
|
|
|
- }
|
|
|
- bigstring2 << "\"}";
|
|
|
- sv.push_back(bigstring2.str());
|
|
|
- sw.push_back(bigwire2.str());
|
|
|
-
|
|
|
-
|
|
|
- BOOST_FOREACH(std::string s, sv) {
|
|
|
- // also test << operator, which uses Element::str()
|
|
|
- el = Element::createFromString(s);
|
|
|
- EXPECT_EQ(s, el->str());
|
|
|
- wire = el->toWire();
|
|
|
- /*
|
|
|
- std::cout << "Encoded wire format:" << std::endl;
|
|
|
- my_print(wire);
|
|
|
- std::cout << "Expecting:" << std::endl;
|
|
|
- my_print(sw.at(0));
|
|
|
- */
|
|
|
- EXPECT_EQ(sw.at(0), wire);
|
|
|
- sw.erase(sw.begin());
|
|
|
- decoded_el = Element::fromWire(wire);
|
|
|
- EXPECT_EQ(s, decoded_el->str());
|
|
|
- }
|
|
|
-
|
|
|
- //EXPECT_THROW(Element::fromWire("Skan\004name\050\003foo"), DecodeError);
|
|
|
- EXPECT_THROW(Element::fromWire("Skan\004name\050"), DecodeError);
|
|
|
- EXPECT_THROW(Element::fromWire("Skan\004na"), DecodeError);
|
|
|
- EXPECT_THROW(Element::fromWire("Skan\004name\050\003fo"), DecodeError);
|
|
|
- EXPECT_NO_THROW(Element::fromWire("Skan\004name\041\003foo"));
|
|
|
- EXPECT_THROW(Element::fromWire("Skan\004name\041\003fo"), DecodeError);
|
|
|
- EXPECT_NO_THROW(Element::fromWire("Skan\004name\044\001a"));
|
|
|
- EXPECT_THROW(Element::fromWire("Skab\004name\050\003foo"), DecodeError);
|
|
|
-
|
|
|
- //EXPECT_EQ("\047\0031.2", Element::create(1.2)->toWire(0));
|
|
|
- EXPECT_EQ("\046\0011", Element::createFromString("[ 1 ]")->toWire(1));
|
|
|
-
|
|
|
- std::string ddef = "{\"data_specification\": {\"config_data\": [ {\"item_default\": \"Hello, world!\", \"item_name\": \"default_name\", \"item_optional\": False, \"item_type\": \"string\"}, {\"item_default\": [ ], \"item_name\": \"zone_list\", \"item_optional\": False, \"item_type\": \"list\", \"list_item_spec\": {\"item_name\": \"zone_name\", \"item_optional\": True, \"item_type\": \"string\"}} ], \"module_name\": \"Auth\"}}";
|
|
|
- //std::string ddef = "{\"aaa\": 123, \"test\": [ ], \"zzz\": 123}";
|
|
|
- ElementPtr ddef_el = Element::createFromString(ddef);
|
|
|
- std::string ddef_wire = ddef_el->toWire();
|
|
|
- ElementPtr ddef_el2 = Element::fromWire(ddef_wire);
|
|
|
- std::string ddef2 = ddef_el2->str();
|
|
|
- EXPECT_EQ(ddef, ddef2);
|
|
|
+ // Wire format is now plain JSON.
|
|
|
+ ElementPtr el;
|
|
|
+ EXPECT_EQ("1", Element::create(1)->toWire());
|
|
|
+ EXPECT_EQ("1.1", Element::create(1.1)->toWire());
|
|
|
+ EXPECT_EQ("true", Element::create(true)->toWire());
|
|
|
+ EXPECT_EQ("false", Element::create(false)->toWire());
|
|
|
+ EXPECT_EQ("null", Element::create()->toWire());
|
|
|
+ EXPECT_EQ("\"a string\"", Element::create("a string")->toWire());
|
|
|
+ EXPECT_EQ("[ \"a\", \"list\" ]", Element::fromJSON("[ \"a\", \"list\" ]")->toWire());
|
|
|
+ EXPECT_EQ("{ \"a\": \"map\" }", Element::fromJSON("{ \"a\": \"map\" }")->toWire());
|
|
|
+
|
|
|
+ EXPECT_EQ("1", Element::fromWire("1")->str());
|
|
|
+
|
|
|
+ std::stringstream ss;
|
|
|
+ ss << "1";
|
|
|
+ EXPECT_EQ("1", Element::fromWire(ss, 1)->str());
|
|
|
+
|
|
|
+ // Some malformed JSON input
|
|
|
+ EXPECT_THROW(Element::fromJSON("{\":"), isc::data::JSONError);
|
|
|
+ EXPECT_THROW(Element::fromJSON("]"), isc::data::JSONError);
|
|
|
+ EXPECT_THROW(Element::fromJSON("[ 1, 2, }"), isc::data::JSONError);
|
|
|
}
|
|
|
|
|
|
-ElementPtr efs(const std::string& str) {
|
|
|
- return Element::createFromString(str);
|
|
|
+static ElementPtr
|
|
|
+efs(const std::string& str) {
|
|
|
+ return Element::fromJSON(str);
|
|
|
}
|
|
|
|
|
|
TEST(Element, equals) {
|
|
|
// why does EXPECT_EQ not work?
|
|
|
- EXPECT_TRUE(efs("1") == efs("1"));
|
|
|
- EXPECT_FALSE(efs("1") == efs("2"));
|
|
|
- EXPECT_FALSE(efs("1") == efs("\"1\""));
|
|
|
- EXPECT_FALSE(efs("1") == efs("[]"));
|
|
|
- EXPECT_FALSE(efs("1") == efs("True"));
|
|
|
- EXPECT_FALSE(efs("1") == efs("{}"));
|
|
|
-
|
|
|
- EXPECT_TRUE(efs("1.1") == efs("1.1"));
|
|
|
- EXPECT_FALSE(efs("1.0") == efs("1"));
|
|
|
- EXPECT_FALSE(efs("1.1") == efs("\"1\""));
|
|
|
- EXPECT_FALSE(efs("1.1") == efs("[]"));
|
|
|
- EXPECT_FALSE(efs("1.1") == efs("True"));
|
|
|
- EXPECT_FALSE(efs("1.1") == efs("{}"));
|
|
|
-
|
|
|
- EXPECT_TRUE(efs("True") == efs("True"));
|
|
|
- EXPECT_FALSE(efs("True") == efs("False"));
|
|
|
- EXPECT_FALSE(efs("True") == efs("1"));
|
|
|
- EXPECT_FALSE(efs("True") == efs("\"1\""));
|
|
|
- EXPECT_FALSE(efs("True") == efs("[]"));
|
|
|
- EXPECT_FALSE(efs("True") == efs("{}"));
|
|
|
-
|
|
|
- EXPECT_TRUE(efs("\"foo\"") == efs("\"foo\""));
|
|
|
- EXPECT_FALSE(efs("\"foo\"") == efs("\"bar\""));
|
|
|
- EXPECT_FALSE(efs("\"foo\"") == efs("1"));
|
|
|
- EXPECT_FALSE(efs("\"foo\"") == efs("\"1\""));
|
|
|
- EXPECT_FALSE(efs("\"foo\"") == efs("True"));
|
|
|
- EXPECT_FALSE(efs("\"foo\"") == efs("[]"));
|
|
|
- EXPECT_FALSE(efs("\"foo\"") == efs("{}"));
|
|
|
-
|
|
|
- EXPECT_TRUE(efs("[]") == efs("[]"));
|
|
|
- EXPECT_TRUE(efs("[ 1, 2, 3 ]") == efs("[ 1, 2, 3 ]"));
|
|
|
- EXPECT_TRUE(efs("[ \"a\", [ True, 1], 2.2 ]") == efs("[ \"a\", [ True, 1], 2.2 ]"));
|
|
|
- EXPECT_FALSE(efs("[ \"a\", [ True, 1], 2.2 ]") == efs("[ \"a\", [ True, 2], 2.2 ]"));
|
|
|
- EXPECT_FALSE(efs("[]") == efs("[1]"));
|
|
|
- EXPECT_FALSE(efs("[]") == efs("1"));
|
|
|
- EXPECT_FALSE(efs("[]") == efs("\"1\""));
|
|
|
- EXPECT_FALSE(efs("[]") == efs("{}"));
|
|
|
-
|
|
|
- EXPECT_TRUE(efs("{}") == efs("{}"));
|
|
|
- EXPECT_TRUE(efs("{ \"foo\": \"bar\" }") == efs("{ \"foo\": \"bar\" }"));
|
|
|
- EXPECT_TRUE(efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar\" } }") == efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar\" } }"));
|
|
|
- EXPECT_FALSE(efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar\" } }") == efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar2\" } }"));
|
|
|
- EXPECT_FALSE(efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar\" } }") == efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\", 1 ], \"item3\": { \"foo\": \"bar\" } }"));
|
|
|
- EXPECT_FALSE(efs("{ \"foo\": \"bar\" }") == efs("1"));
|
|
|
- EXPECT_FALSE(efs("{ \"foo\": \"bar\" }") == efs("\"1\""));
|
|
|
- EXPECT_FALSE(efs("{ \"foo\": \"bar\" }") == efs("[]"));
|
|
|
- EXPECT_FALSE(efs("{ \"foo\": \"bar\" }") == efs("{}"));
|
|
|
+ EXPECT_EQ(efs("1"), efs("1"));
|
|
|
+ EXPECT_NE(efs("1"), efs("2"));
|
|
|
+ EXPECT_NE(efs("1"), efs("\"1\""));
|
|
|
+ EXPECT_NE(efs("1"), efs("[]"));
|
|
|
+ EXPECT_NE(efs("1"), efs("True"));
|
|
|
+ EXPECT_NE(efs("1"), efs("{}"));
|
|
|
+
|
|
|
+ EXPECT_EQ(efs("1.1"), efs("1.1"));
|
|
|
+ EXPECT_NE(efs("1.0"), efs("1"));
|
|
|
+ EXPECT_NE(efs("1.1"), efs("\"1\""));
|
|
|
+ EXPECT_NE(efs("1.1"), efs("[]"));
|
|
|
+ EXPECT_NE(efs("1.1"), efs("True"));
|
|
|
+ EXPECT_NE(efs("1.1"), efs("{}"));
|
|
|
+
|
|
|
+ EXPECT_EQ(efs("True"), efs("True"));
|
|
|
+ EXPECT_NE(efs("True"), efs("False"));
|
|
|
+ EXPECT_NE(efs("True"), efs("1"));
|
|
|
+ EXPECT_NE(efs("True"), efs("\"1\""));
|
|
|
+ EXPECT_NE(efs("True"), efs("[]"));
|
|
|
+ EXPECT_NE(efs("True"), efs("{}"));
|
|
|
+
|
|
|
+ EXPECT_EQ(efs("\"foo\""), efs("\"foo\""));
|
|
|
+ EXPECT_NE(efs("\"foo\""), efs("\"bar\""));
|
|
|
+ EXPECT_NE(efs("\"foo\""), efs("1"));
|
|
|
+ EXPECT_NE(efs("\"foo\""), efs("\"1\""));
|
|
|
+ EXPECT_NE(efs("\"foo\""), efs("True"));
|
|
|
+ EXPECT_NE(efs("\"foo\""), efs("[]"));
|
|
|
+ EXPECT_NE(efs("\"foo\""), efs("{}"));
|
|
|
+
|
|
|
+ EXPECT_EQ(efs("[]"), efs("[]"));
|
|
|
+ EXPECT_EQ(efs("[ 1, 2, 3 ]"), efs("[ 1, 2, 3 ]"));
|
|
|
+ EXPECT_EQ(efs("[ \"a\", [ True, 1], 2.2 ]"), efs("[ \"a\", [ True, 1], 2.2 ]"));
|
|
|
+ EXPECT_NE(efs("[ \"a\", [ True, 1], 2.2 ]"), efs("[ \"a\", [ True, 2], 2.2 ]"));
|
|
|
+ EXPECT_NE(efs("[]"), efs("[1]"));
|
|
|
+ EXPECT_NE(efs("[]"), efs("1"));
|
|
|
+ EXPECT_NE(efs("[]"), efs("\"1\""));
|
|
|
+ EXPECT_NE(efs("[]"), efs("{}"));
|
|
|
+
|
|
|
+ EXPECT_EQ(efs("{}"), efs("{}"));
|
|
|
+ EXPECT_EQ(efs("{ \"foo\": \"bar\" }"), efs("{ \"foo\": \"bar\" }"));
|
|
|
+ EXPECT_EQ(efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar\" } }"), efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar\" } }"));
|
|
|
+ EXPECT_NE(efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar\" } }"), efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar2\" } }"));
|
|
|
+ EXPECT_NE(efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\" ], \"item3\": { \"foo\": \"bar\" } }"), efs("{ \"item1\": 1, \"item2\": [ \"a\", \"list\", 1 ], \"item3\": { \"foo\": \"bar\" } }"));
|
|
|
+ EXPECT_NE(efs("{ \"foo\": \"bar\" }"), efs("1"));
|
|
|
+ EXPECT_NE(efs("{ \"foo\": \"bar\" }"), efs("\"1\""));
|
|
|
+ EXPECT_NE(efs("{ \"foo\": \"bar\" }"), efs("[]"));
|
|
|
+ EXPECT_NE(efs("{ \"foo\": \"bar\" }"), efs("{}"));
|
|
|
+ EXPECT_NE(efs("{ \"foo\": \"bar\" }"), efs("{ \"something\": \"different\" }"));
|
|
|
+
|
|
|
+ EXPECT_EQ(efs("null"), Element::create());
|
|
|
}
|
|
|
|
|
|
TEST(Element, removeIdentical) {
|
|
|
- ElementPtr a = Element::createFromString("{}");
|
|
|
- ElementPtr b = Element::createFromString("{}");
|
|
|
- ElementPtr c = Element::createFromString("{}");
|
|
|
+ ElementPtr a = Element::createMap();
|
|
|
+ ElementPtr b = Element::createMap();
|
|
|
+ ElementPtr c = Element::createMap();
|
|
|
removeIdentical(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
|
|
|
- a = Element::createFromString("{ \"a\": 1 }");
|
|
|
- b = Element::createFromString("{ \"a\": 1 }");
|
|
|
- c = Element::createFromString("{}");
|
|
|
+ a = Element::fromJSON("{ \"a\": 1 }");
|
|
|
+ b = Element::fromJSON("{ \"a\": 1 }");
|
|
|
+ c = Element::createMap();
|
|
|
removeIdentical(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
|
|
|
- a = Element::createFromString("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
- b = Element::createFromString("{}");
|
|
|
- c = Element::createFromString("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
+ a = Element::fromJSON("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
+ b = Element::createMap();
|
|
|
+ c = Element::fromJSON("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
removeIdentical(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
|
|
|
- a = Element::createFromString("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
- b = Element::createFromString("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
- c = Element::createFromString("{}");
|
|
|
+ a = Element::fromJSON("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
+ b = Element::fromJSON("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
+ c = Element::createMap();
|
|
|
removeIdentical(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
|
|
|
- a = Element::createFromString("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
- b = Element::createFromString("{ \"a\": 1, \"b\": [ 1, 3 ] }");
|
|
|
- c = Element::createFromString("{ \"b\": [ 1, 2 ] }");
|
|
|
+ a = Element::fromJSON("{ \"a\": 1, \"b\": [ 1, 2 ] }");
|
|
|
+ b = Element::fromJSON("{ \"a\": 1, \"b\": [ 1, 3 ] }");
|
|
|
+ c = Element::fromJSON("{ \"b\": [ 1, 2 ] }");
|
|
|
removeIdentical(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
|
|
|
- a = Element::createFromString("{ \"a\": { \"b\": \"c\" } }");
|
|
|
- b = Element::createFromString("{}");
|
|
|
- c = Element::createFromString("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ a = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ b = Element::createMap();
|
|
|
+ c = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
removeIdentical(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
|
|
|
- a = Element::createFromString("{ \"a\": { \"b\": \"c\" } }");
|
|
|
- b = Element::createFromString("{ \"a\": { \"b\": \"c\" } }");
|
|
|
- c = Element::createFromString("{}");
|
|
|
+ a = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ b = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ c = Element::createMap();
|
|
|
removeIdentical(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
|
|
|
- a = Element::createFromString("{ \"a\": { \"b\": \"c\" } }");
|
|
|
- b = Element::createFromString("{ \"a\": { \"b\": \"d\" } }");
|
|
|
- c = Element::createFromString("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ a = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ b = Element::fromJSON("{ \"a\": { \"b\": \"d\" } }");
|
|
|
+ c = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
removeIdentical(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
+
|
|
|
+ EXPECT_THROW(removeIdentical(Element::create(1), Element::create(2)), TypeError);
|
|
|
}
|
|
|
|
|
|
TEST(Element, merge)
|
|
|
{
|
|
|
- ElementPtr a = Element::createFromString("{}");
|
|
|
- ElementPtr b = Element::createFromString("{}");
|
|
|
- ElementPtr c = Element::createFromString("{}");
|
|
|
+ ElementPtr a = Element::createMap();
|
|
|
+ ElementPtr b = Element::createMap();
|
|
|
+ ElementPtr c = Element::createMap();
|
|
|
merge(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
|
|
|
- a = Element::createFromString("1");
|
|
|
- b = Element::createFromString("{}");
|
|
|
+ a = Element::fromJSON("1");
|
|
|
+ b = Element::createMap();
|
|
|
EXPECT_THROW(merge(a, b), TypeError);
|
|
|
|
|
|
- a = Element::createFromString("{}");
|
|
|
- b = Element::createFromString("{ \"a\": 1 }");
|
|
|
- c = Element::createFromString("{ \"a\": 1 }");
|
|
|
+ a = Element::createMap();
|
|
|
+ b = Element::fromJSON("{ \"a\": 1 }");
|
|
|
+ c = Element::fromJSON("{ \"a\": 1 }");
|
|
|
+ merge(a, b);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
+
|
|
|
+ a = Element::createMap();
|
|
|
+ b = Element::fromJSON("{ \"a\": 1 }");
|
|
|
+ c = Element::fromJSON("{ \"a\": 1 }");
|
|
|
+ merge(b, a);
|
|
|
+ EXPECT_EQ(b, c);
|
|
|
+
|
|
|
+ a = Element::fromJSON("{ \"a\": 1 }");
|
|
|
+ b = Element::fromJSON("{ \"a\": 2 }");
|
|
|
+ c = Element::fromJSON("{ \"a\": 2 }");
|
|
|
merge(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
+
|
|
|
+ a = Element::fromJSON("{ \"a\": 1 }");
|
|
|
+ b = Element::fromJSON("{ \"a\": 2 }");
|
|
|
+ c = Element::fromJSON("{ \"a\": 1 }");
|
|
|
+ merge(b, a);
|
|
|
+ EXPECT_EQ(b, c);
|
|
|
|
|
|
- a = Element::createFromString("{ \"a\": 1 }");
|
|
|
- b = Element::createFromString("{ \"a\": 2 }");
|
|
|
- c = Element::createFromString("{ \"a\": 2 }");
|
|
|
+ a = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ b = Element::fromJSON("{ \"a\": { \"b\": \"d\" } }");
|
|
|
+ c = Element::fromJSON("{ \"a\": { \"b\": \"d\" } }");
|
|
|
merge(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
|
|
|
- a = Element::createFromString("{ \"a\": { \"b\": \"c\" } }");
|
|
|
- b = Element::createFromString("{ \"a\": { \"b\": \"d\" } }");
|
|
|
- c = Element::createFromString("{ \"a\": { \"b\": \"d\" } }");
|
|
|
+ a = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ b = Element::fromJSON("{ \"a\": { \"b\": \"d\" } }");
|
|
|
+ c = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ merge(b, a);
|
|
|
+ EXPECT_EQ(b, c);
|
|
|
+
|
|
|
+ a = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ b = Element::fromJSON("{ \"a\": null }");
|
|
|
+ c = Element::fromJSON("{ }");
|
|
|
merge(a, b);
|
|
|
- EXPECT_TRUE(a == c);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
+
|
|
|
+ a = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ b = Element::fromJSON("{ \"a\": null }");
|
|
|
+ c = Element::fromJSON("{ \"a\": { \"b\": \"c\" } }");
|
|
|
+ merge(b, a);
|
|
|
+ EXPECT_EQ(b, c);
|
|
|
+
|
|
|
+ // And some tests with multiple values
|
|
|
+ a = Element::fromJSON("{ \"a\": 1, \"b\": true, \"c\": null }");
|
|
|
+ b = Element::fromJSON("{ \"a\": 1, \"b\": null, \"c\": \"a string\" }");
|
|
|
+ c = Element::fromJSON("{ \"a\": 1, \"c\": \"a string\" }");
|
|
|
+ merge(a, b);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
+
|
|
|
+ a = Element::fromJSON("{ \"a\": 1, \"b\": true, \"c\": null }");
|
|
|
+ b = Element::fromJSON("{ \"a\": 1, \"b\": null, \"c\": \"a string\" }");
|
|
|
+ c = Element::fromJSON("{ \"a\": 1, \"b\": true }");
|
|
|
+ merge(b, a);
|
|
|
+ EXPECT_EQ(b, c);
|
|
|
+
|
|
|
+ a = Element::fromJSON("{ \"a\": 1, \"b\": 2, \"c\": 3 }");
|
|
|
+ b = Element::fromJSON("{ \"a\": 3, \"b\": 2, \"c\": 1 }");
|
|
|
+ c = Element::fromJSON("{ \"a\": 3, \"b\": 2, \"c\": 1 }");
|
|
|
+ merge(a, b);
|
|
|
+ EXPECT_EQ(a, c);
|
|
|
+
|
|
|
+ a = Element::fromJSON("{ \"a\": 1, \"b\": 2, \"c\": 3 }");
|
|
|
+ b = Element::fromJSON("{ \"a\": 3, \"b\": 2, \"c\": 1 }");
|
|
|
+ c = Element::fromJSON("{ \"a\": 1, \"b\": 2, \"c\": 3 }");
|
|
|
+ merge(b, a);
|
|
|
+ EXPECT_EQ(b, c);
|
|
|
|
|
|
}
|