summaryrefslogtreecommitdiff
path: root/cpp/msgpackc_test.cpp
diff options
context:
space:
mode:
authorfrsyuki <frsyuki@users.sourceforge.jp>2010-04-18 00:08:03 +0900
committerfrsyuki <frsyuki@users.sourceforge.jp>2010-04-18 00:08:03 +0900
commitab8e0c9e31585b24f1d4cbfb1e73b0ce249e408a (patch)
tree042100bffb170e6bec88cc497345bd4074e2f067 /cpp/msgpackc_test.cpp
parentc3f43fb0cf14f596a9ebb1c30b0417b3a8ba9958 (diff)
downloadmsgpack-python-ab8e0c9e31585b24f1d4cbfb1e73b0ce249e408a.tar.gz
c,cpp: reforms source tree
Diffstat (limited to 'cpp/msgpackc_test.cpp')
-rw-r--r--cpp/msgpackc_test.cpp424
1 files changed, 424 insertions, 0 deletions
diff --git a/cpp/msgpackc_test.cpp b/cpp/msgpackc_test.cpp
new file mode 100644
index 0000000..f5646ea
--- /dev/null
+++ b/cpp/msgpackc_test.cpp
@@ -0,0 +1,424 @@
+#include "msgpack.h"
+
+#include <math.h>
+#include <vector>
+#include <limits>
+
+#include <gtest/gtest.h>
+
+using namespace std;
+
+const unsigned int kLoop = 10000;
+const double kEPS = 1e-10;
+
+#define GEN_TEST_SIGNED(test_type, func_type) \
+ do { \
+ vector<test_type> v; \
+ v.push_back(0); \
+ v.push_back(1); \
+ v.push_back(-1); \
+ v.push_back(numeric_limits<test_type>::min()); \
+ v.push_back(numeric_limits<test_type>::max()); \
+ for (unsigned int i = 0; i < kLoop; i++) \
+ v.push_back(rand()); \
+ for (unsigned int i = 0; i < v.size() ; i++) { \
+ test_type val = v[i]; \
+ msgpack_sbuffer sbuf; \
+ msgpack_sbuffer_init(&sbuf); \
+ msgpack_packer pk; \
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write); \
+ msgpack_pack_##func_type(&pk, val); \
+ msgpack_zone z; \
+ msgpack_zone_init(&z, 2048); \
+ msgpack_object obj; \
+ msgpack_unpack_return ret = \
+ msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj); \
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret); \
+ if (val < 0) { \
+ EXPECT_EQ(MSGPACK_OBJECT_NEGATIVE_INTEGER, obj.type); \
+ EXPECT_EQ(val, obj.via.i64); \
+ } else { \
+ EXPECT_EQ(MSGPACK_OBJECT_POSITIVE_INTEGER, obj.type); \
+ EXPECT_EQ(val, obj.via.u64); \
+ } \
+ msgpack_zone_destroy(&z); \
+ msgpack_sbuffer_destroy(&sbuf); \
+ } \
+ } while(0)
+
+#define GEN_TEST_UNSIGNED(test_type, func_type) \
+ do { \
+ vector<test_type> v; \
+ v.push_back(0); \
+ v.push_back(1); \
+ v.push_back(2); \
+ v.push_back(numeric_limits<test_type>::min()); \
+ v.push_back(numeric_limits<test_type>::max()); \
+ for (unsigned int i = 0; i < kLoop; i++) \
+ v.push_back(rand()); \
+ for (unsigned int i = 0; i < v.size() ; i++) { \
+ test_type val = v[i]; \
+ msgpack_sbuffer sbuf; \
+ msgpack_sbuffer_init(&sbuf); \
+ msgpack_packer pk; \
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write); \
+ msgpack_pack_##func_type(&pk, val); \
+ msgpack_zone z; \
+ msgpack_zone_init(&z, 2048); \
+ msgpack_object obj; \
+ msgpack_unpack_return ret = \
+ msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj); \
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret); \
+ EXPECT_EQ(MSGPACK_OBJECT_POSITIVE_INTEGER, obj.type); \
+ EXPECT_EQ(val, obj.via.u64); \
+ msgpack_zone_destroy(&z); \
+ msgpack_sbuffer_destroy(&sbuf); \
+ } \
+ } while(0)
+
+TEST(MSGPACKC, simple_buffer_short)
+{
+ GEN_TEST_SIGNED(short, short);
+}
+
+TEST(MSGPACKC, simple_buffer_int)
+{
+ GEN_TEST_SIGNED(int, int);
+}
+
+TEST(MSGPACKC, simple_buffer_long)
+{
+ GEN_TEST_SIGNED(long, long);
+}
+
+TEST(MSGPACKC, simple_buffer_long_long)
+{
+ GEN_TEST_SIGNED(long long, long_long);
+}
+
+TEST(MSGPACKC, simple_buffer_unsigned_short)
+{
+ GEN_TEST_UNSIGNED(unsigned short, unsigned_short);
+}
+
+TEST(MSGPACKC, simple_buffer_unsigned_int)
+{
+ GEN_TEST_UNSIGNED(unsigned int, unsigned_int);
+}
+
+TEST(MSGPACKC, simple_buffer_unsigned_long)
+{
+ GEN_TEST_UNSIGNED(unsigned long, unsigned_long);
+}
+
+TEST(MSGPACKC, simple_buffer_unsigned_long_long)
+{
+ GEN_TEST_UNSIGNED(unsigned long long, unsigned_long_long);
+}
+
+TEST(MSGPACKC, simple_buffer_uint8)
+{
+ GEN_TEST_UNSIGNED(uint8_t, uint8);
+}
+
+TEST(MSGPACKC, simple_buffer_uint16)
+{
+ GEN_TEST_UNSIGNED(uint16_t, uint16);
+}
+
+TEST(MSGPACKC, simple_buffer_uint32)
+{
+ GEN_TEST_UNSIGNED(uint32_t, uint32);
+}
+
+TEST(MSGPACKC, simple_buffer_uint64)
+{
+ GEN_TEST_UNSIGNED(uint64_t, uint64);
+}
+
+TEST(MSGPACKC, simple_buffer_int8)
+{
+ GEN_TEST_SIGNED(int8_t, int8);
+}
+
+TEST(MSGPACKC, simple_buffer_int16)
+{
+ GEN_TEST_SIGNED(int16_t, int16);
+}
+
+TEST(MSGPACKC, simple_buffer_int32)
+{
+ GEN_TEST_SIGNED(int32_t, int32);
+}
+
+TEST(MSGPACKC, simple_buffer_int64)
+{
+ GEN_TEST_SIGNED(int64_t, int64);
+}
+
+TEST(MSGPACKC, simple_buffer_float)
+{
+ vector<float> v;
+ v.push_back(0.0);
+ v.push_back(1.0);
+ v.push_back(-1.0);
+ v.push_back(numeric_limits<float>::min());
+ v.push_back(numeric_limits<float>::max());
+ v.push_back(nanf("tag"));
+ v.push_back(1.0/0.0); // inf
+ v.push_back(-(1.0/0.0)); // -inf
+ for (unsigned int i = 0; i < kLoop; i++) {
+ v.push_back(drand48());
+ v.push_back(-drand48());
+ }
+
+ for (unsigned int i = 0; i < v.size() ; i++) {
+ float val = v[i];
+ msgpack_sbuffer sbuf;
+ msgpack_sbuffer_init(&sbuf);
+ msgpack_packer pk;
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
+ msgpack_pack_float(&pk, val);
+ msgpack_zone z;
+ msgpack_zone_init(&z, 2048);
+ msgpack_object obj;
+ msgpack_unpack_return ret =
+ msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
+ EXPECT_EQ(MSGPACK_OBJECT_DOUBLE, obj.type);
+ if (isnan(val))
+ EXPECT_TRUE(isnan(obj.via.dec));
+ else if (isinf(val))
+ EXPECT_TRUE(isinf(obj.via.dec));
+ else
+ EXPECT_TRUE(fabs(obj.via.dec - val) <= kEPS);
+ msgpack_zone_destroy(&z);
+ msgpack_sbuffer_destroy(&sbuf);
+ }
+}
+
+TEST(MSGPACKC, simple_buffer_double)
+{
+ vector<double> v;
+ v.push_back(0.0);
+ v.push_back(-0.0);
+ v.push_back(1.0);
+ v.push_back(-1.0);
+ v.push_back(numeric_limits<double>::min());
+ v.push_back(numeric_limits<double>::max());
+ v.push_back(nan("tag"));
+ v.push_back(1.0/0.0); // inf
+ v.push_back(-(1.0/0.0)); // -inf
+ for (unsigned int i = 0; i < kLoop; i++) {
+ v.push_back(drand48());
+ v.push_back(-drand48());
+ }
+
+ for (unsigned int i = 0; i < v.size() ; i++) {
+ double val = v[i];
+ msgpack_sbuffer sbuf;
+ msgpack_sbuffer_init(&sbuf);
+ msgpack_packer pk;
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
+ msgpack_pack_double(&pk, val);
+ msgpack_zone z;
+ msgpack_zone_init(&z, 2048);
+ msgpack_object obj;
+ msgpack_unpack_return ret =
+ msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
+ EXPECT_EQ(MSGPACK_OBJECT_DOUBLE, obj.type);
+ if (isnan(val))
+ EXPECT_TRUE(isnan(obj.via.dec));
+ else if (isinf(val))
+ EXPECT_TRUE(isinf(obj.via.dec));
+ else
+ EXPECT_TRUE(fabs(obj.via.dec - val) <= kEPS);
+ msgpack_zone_destroy(&z);
+ msgpack_sbuffer_destroy(&sbuf);
+ }
+}
+
+TEST(MSGPACKC, simple_buffer_nil)
+{
+ msgpack_sbuffer sbuf;
+ msgpack_sbuffer_init(&sbuf);
+ msgpack_packer pk;
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
+ msgpack_pack_nil(&pk);
+ msgpack_zone z;
+ msgpack_zone_init(&z, 2048);
+ msgpack_object obj;
+ msgpack_unpack_return ret =
+ msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
+ EXPECT_EQ(MSGPACK_OBJECT_NIL, obj.type);
+ msgpack_zone_destroy(&z);
+ msgpack_sbuffer_destroy(&sbuf);
+}
+
+TEST(MSGPACKC, simple_buffer_true)
+{
+ msgpack_sbuffer sbuf;
+ msgpack_sbuffer_init(&sbuf);
+ msgpack_packer pk;
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
+ msgpack_pack_true(&pk);
+ msgpack_zone z;
+ msgpack_zone_init(&z, 2048);
+ msgpack_object obj;
+ msgpack_unpack_return ret =
+ msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
+ EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, obj.type);
+ EXPECT_EQ(true, obj.via.boolean);
+ msgpack_zone_destroy(&z);
+ msgpack_sbuffer_destroy(&sbuf);
+}
+
+TEST(MSGPACKC, simple_buffer_false)
+{
+ msgpack_sbuffer sbuf;
+ msgpack_sbuffer_init(&sbuf);
+ msgpack_packer pk;
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
+ msgpack_pack_false(&pk);
+ msgpack_zone z;
+ msgpack_zone_init(&z, 2048);
+ msgpack_object obj;
+ msgpack_unpack_return ret =
+ msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
+ EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, obj.type);
+ EXPECT_EQ(false, obj.via.boolean);
+ msgpack_zone_destroy(&z);
+ msgpack_sbuffer_destroy(&sbuf);
+}
+
+TEST(MSGPACKC, simple_buffer_array)
+{
+ unsigned int array_size = 5;
+
+ msgpack_sbuffer sbuf;
+ msgpack_sbuffer_init(&sbuf);
+ msgpack_packer pk;
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
+ msgpack_pack_array(&pk, array_size);
+ msgpack_pack_nil(&pk);
+ msgpack_pack_true(&pk);
+ msgpack_pack_false(&pk);
+ msgpack_pack_int(&pk, 10);
+ msgpack_pack_int(&pk, -10);
+
+ msgpack_zone z;
+ msgpack_zone_init(&z, 2048);
+ msgpack_object obj;
+ msgpack_unpack_return ret;
+ ret = msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
+ EXPECT_EQ(MSGPACK_OBJECT_ARRAY, obj.type);
+ EXPECT_EQ(array_size, obj.via.array.size);
+
+ for (unsigned int i = 0; i < obj.via.array.size; i++) {
+ msgpack_object o = obj.via.array.ptr[i];
+ switch (i) {
+ case 0:
+ EXPECT_EQ(MSGPACK_OBJECT_NIL, o.type);
+ break;
+ case 1:
+ EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, o.type);
+ EXPECT_EQ(true, o.via.boolean);
+ break;
+ case 2:
+ EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, o.type);
+ EXPECT_EQ(false, o.via.boolean);
+ break;
+ case 3:
+ EXPECT_EQ(MSGPACK_OBJECT_POSITIVE_INTEGER, o.type);
+ EXPECT_EQ(10, o.via.u64);
+ break;
+ case 4:
+ EXPECT_EQ(MSGPACK_OBJECT_NEGATIVE_INTEGER, o.type);
+ EXPECT_EQ(-10, o.via.i64);
+ break;
+ }
+ }
+
+ msgpack_zone_destroy(&z);
+ msgpack_sbuffer_destroy(&sbuf);
+}
+
+TEST(MSGPACKC, simple_buffer_map)
+{
+ unsigned int map_size = 2;
+
+ msgpack_sbuffer sbuf;
+ msgpack_sbuffer_init(&sbuf);
+ msgpack_packer pk;
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
+ msgpack_pack_map(&pk, map_size);
+ msgpack_pack_true(&pk);
+ msgpack_pack_false(&pk);
+ msgpack_pack_int(&pk, 10);
+ msgpack_pack_int(&pk, -10);
+
+ msgpack_zone z;
+ msgpack_zone_init(&z, 2048);
+ msgpack_object obj;
+ msgpack_unpack_return ret;
+ ret = msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
+ EXPECT_EQ(MSGPACK_OBJECT_MAP, obj.type);
+ EXPECT_EQ(map_size, obj.via.map.size);
+
+ for (unsigned int i = 0; i < map_size; i++) {
+ msgpack_object key = obj.via.map.ptr[i].key;
+ msgpack_object val = obj.via.map.ptr[i].val;
+ switch (i) {
+ case 0:
+ EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, key.type);
+ EXPECT_EQ(true, key.via.boolean);
+ EXPECT_EQ(MSGPACK_OBJECT_BOOLEAN, val.type);
+ EXPECT_EQ(false, val.via.boolean);
+ break;
+ case 1:
+ EXPECT_EQ(MSGPACK_OBJECT_POSITIVE_INTEGER, key.type);
+ EXPECT_EQ(10, key.via.u64);
+ EXPECT_EQ(MSGPACK_OBJECT_NEGATIVE_INTEGER, val.type);
+ EXPECT_EQ(-10, val.via.i64);
+ break;
+ }
+ }
+
+ msgpack_zone_destroy(&z);
+ msgpack_sbuffer_destroy(&sbuf);
+}
+
+TEST(MSGPACKC, simple_buffer_raw)
+{
+ unsigned int raw_size = 7;
+
+ msgpack_sbuffer sbuf;
+ msgpack_sbuffer_init(&sbuf);
+ msgpack_packer pk;
+ msgpack_packer_init(&pk, &sbuf, msgpack_sbuffer_write);
+ msgpack_pack_raw(&pk, raw_size);
+ msgpack_pack_raw_body(&pk, "fr", 2);
+ msgpack_pack_raw_body(&pk, "syuki", 5);
+ // invalid data
+ msgpack_pack_raw_body(&pk, "", 0);
+ msgpack_pack_raw_body(&pk, "kzk", 0);
+
+ msgpack_zone z;
+ msgpack_zone_init(&z, 2048);
+ msgpack_object obj;
+ msgpack_unpack_return ret;
+ ret = msgpack_unpack(sbuf.data, sbuf.size, NULL, &z, &obj);
+ EXPECT_EQ(MSGPACK_UNPACK_SUCCESS, ret);
+ EXPECT_EQ(MSGPACK_OBJECT_RAW, obj.type);
+ EXPECT_EQ(raw_size, obj.via.raw.size);
+ EXPECT_EQ(0, memcmp("frsyuki", obj.via.raw.ptr, raw_size));
+
+ msgpack_zone_destroy(&z);
+ msgpack_sbuffer_destroy(&sbuf);
+}