add (ugly) stream support
[jansson.git] / test.cc
diff --git a/test.cc b/test.cc
index 7b44bb0..28a83c8 100644 (file)
--- a/test.cc
+++ b/test.cc
@@ -1,5 +1,6 @@
 #include <iostream>
 #include <iomanip>
+#include <malloc.h>
 
 #include "janssonxx.h"
 
@@ -50,17 +51,82 @@ int main() {
        i.next();
        ASSERT_FALSE(i.valid(), "iterator has more values than expected");
 
-       e3 = 12.34;
+       e3 = jansson::Value::from(12.34);
        ASSERT_TRUE(e3.is_number(), "e3 is not a number after assignment");
        ASSERT_EQ(e3.as_real(), 12.34, "e3 has incorrect value after assignment");
 
-       e3 = true;
+       e3 = jansson::Value::from(true);
        ASSERT_TRUE(e3.is_boolean(), "e3 is not a boolean after assignment");
        ASSERT_EQ(e3.as_boolean(), true, "e3 has incorrect value after assignment");
 
-       e3 = "foobar";
+       e3 = jansson::Value::from("foobar");
        ASSERT_TRUE(e3.is_string(), "e3 is not a string after assignment");
        ASSERT_EQ(e3.as_string(), "foobar", "e3 has incorrect value after assignment");
 
+       e3 = jansson::Value::object();
+       ASSERT_TRUE(e3.is_object(), "e3 is not an object after assignment");
+
+       e3 = jansson::Value::null();
+       ASSERT_TRUE(e3.is_null(), "e3 is not null after assignment");
+
+       e3.set_at(0, jansson::Value::from("foobar"));
+       ASSERT_TRUE(e3.is_array(), "e3 is not an array after index assignment");
+       ASSERT_EQ(e3.size(), 1, "e3 has incorrect number of elements after assignment");
+       ASSERT_EQ(e3[0].as_string(), "foobar", "e3[0] has incorrect value after assignment");
+
+       e3.set_at(1, jansson::Value::from("foobar"));
+       ASSERT_TRUE(e3.is_array(), "e3 is not an array after index assignment");
+       ASSERT_EQ(e3.size(), 2, "e3 has incorrect number of elements after assignment");
+       ASSERT_EQ(e3[1].as_string(), "foobar", "e3[0] has incorrect value after assignment");
+
+       e3.set_at(0, jansson::Value::from("barfoo"));
+       ASSERT_TRUE(e3.is_array(), "e3 is not an array after index assignment");
+       ASSERT_EQ(e3.size(), 2, "e3 has incorrect number of elements after assignment");
+       ASSERT_EQ(e3[0].as_string(), "barfoo", "e3[0] has incorrect value after assignment");
+
+       e3.set_at(100, jansson::Value::null());
+       ASSERT_TRUE(e3.is_array(), "e3 is not an array after index assignment");
+       ASSERT_EQ(e3.size(), 2, "e3 has incorrect number of elements after assignment");
+
+       e3.clear();
+       ASSERT_EQ(e3.size(), 0, "e3 has incorrect number of elements after clear");
+
+       e3.set_key("foo", jansson::Value::from("test"));
+       ASSERT_TRUE(e3.is_object(), "e3 is not an object after property assignment");
+       ASSERT_EQ(e3.size(), 1, "e3 has incorrect number of properties after assignment");
+       ASSERT_EQ(e3["foo"].as_string(), "test", "e3.foo has incorrect value after assignment");
+
+       e3.set_key("foo", jansson::Value::from("again"));
+       ASSERT_TRUE(e3.is_object(), "e3 is not an object after property assignment");
+       ASSERT_EQ(e3.size(), 1, "e3 has incorrect number of properties after assignment");
+       ASSERT_EQ(e3["foo"].as_string(), "again", "e3.foo has incorrect value after assignment");
+
+       e3.set_key("bar", jansson::Value::from("test"));
+       ASSERT_TRUE(e3.is_object(), "e3 is not an object after property assignment");
+       ASSERT_EQ(e3.size(), 2, "e3 has incorrect number of properties after assignment");
+       ASSERT_EQ(e3["bar"].as_string(), "test", "e3.foo has incorrect value after assignment");
+
+       e3.clear();
+       ASSERT_EQ(e3.size(), 0, "e3 has incorrect number of properties after clear");
+
+       e3 = jansson::Value::object();
+       e3.set_key("foo", jansson::Value::from("test"));
+       e3.set_key("bar", jansson::Value::from(3));
+       char* out_cstr = e3.save_string(0);
+       string out(out_cstr);
+       free(out_cstr);
+       ASSERT_EQ(out, "{\"bar\": 3,\"foo\": \"test\"}\n", "object did not serialize as expected");
+
+       std::istringstream instr(out);
+       instr >> e3;
+       ASSERT_TRUE(e3.is_object(), "e3 is not an object after stream read");
+       ASSERT_EQ(e3.size(), 2, "e3 has wrong size after stream read");
+       ASSERT_EQ(e3.get("bar").as_integer(), 3, "e3.bar has incorrect value after stream read");
+       ASSERT_EQ(e3.get("foo").as_string(), "test", "ee3.test has incorrect value after stream read");
+
+       std::ostringstream outstr;
+       outstr << e3;
+       ASSERT_EQ(instr.str(), "{\"bar\": 3,\"foo\": \"test\"}\n", "object did not serialize as expected");
+
        return 0;
 }