#include #if defined(__GNUC__) #pragma GCC diagnostic push #pragma GCC diagnostic ignored "-Wconversion" #endif //defined(__GNUC__) #include #if defined(__GNUC__) #pragma GCC diagnostic pop #endif //defined(__GNUC__) #ifdef HAVE_CONFIG_H #include "config.h" #endif // To avoid link error TEST(MSGPACK_CPP17, dummy) { } #if !defined(MSGPACK_USE_CPP03) && __cplusplus >= 201703 // C++17 #if MSGPACK_HAS_INCLUDE() TEST(MSGPACK_CPP17, optional_pack_convert_nil) { std::stringstream ss; std::optional val1; msgpack::pack(ss, val1); std::string const& str = ss.str(); msgpack::object_handle oh = msgpack::unpack(str.data(), str.size()); std::optional val2 = oh.get().as >(); EXPECT_TRUE(val1 == val2); } TEST(MSGPACK_CPP17, optional_pack_convert_int) { std::stringstream ss; std::optional val1 = 1; msgpack::pack(ss, val1); std::string const& str = ss.str(); msgpack::object_handle oh = msgpack::unpack(str.data(), str.size()); std::optional val2 = oh.get().as >(); EXPECT_TRUE(val1 == val2); } TEST(MSGPACK_CPP17, optional_pack_convert_vector) { typedef std::optional > ovi_t; std::stringstream ss; ovi_t val1; std::vector v; v.push_back(1); v.push_back(2); v.push_back(3); val1 = v; msgpack::pack(ss, val1); std::string const& str = ss.str(); msgpack::object_handle oh = msgpack::unpack(str.data(), str.size()); ovi_t val2 = oh.get().as(); EXPECT_TRUE(val1 == val2); } TEST(MSGPACK_CPP17, optional_pack_convert_vector_optional) { typedef std::vector > voi_t; std::stringstream ss; voi_t val1; val1.resize(3); val1[0] = 1; val1[2] = 3; msgpack::pack(ss, val1); std::string const& str = ss.str(); msgpack::object_handle oh = msgpack::unpack(str.data(), str.size()); voi_t val2 = oh.get().as(); EXPECT_TRUE(val1 == val2); } TEST(MSGPACK_CPP17, optional_object_nil) { std::optional val1; msgpack::object obj(val1); std::optional val2 = obj.as >(); EXPECT_TRUE(val1 == val2); } TEST(MSGPACK_CPP17, optional_object_int) { std::optional val1 = 1; msgpack::object obj(val1); std::optional val2 = obj.as >(); EXPECT_TRUE(val1 == val2); } // Compile error as expected /* TEST(MSGPACK_CPP17, optional_object_vector) { typedef std::optional > ovi_t; ovi_t val1; std::vector v; v.push_back(1); v.push_back(2); v.push_back(3); val1 = v; msgpack::object obj(val1); ovi_t val2 = obj.as(); EXPECT_TRUE(val1 == val2); } */ TEST(MSGPACK_CPP17, optional_object_with_zone_nil) { msgpack::zone z; std::optional val1; msgpack::object obj(val1, z); std::optional val2 = obj.as >(); EXPECT_TRUE(val1 == val2); } TEST(MSGPACK_CPP17, optional_object_with_zone_int) { msgpack::zone z; std::optional val1 = 1; msgpack::object obj(val1, z); std::optional val2 = obj.as >(); EXPECT_TRUE(val1 == val2); } TEST(MSGPACK_CPP17, optional_object_with_zone_vector_optional) { typedef std::vector > voi_t; msgpack::zone z; voi_t val1; val1.resize(3); val1[0] = 1; val1[2] = 3; msgpack::object obj(val1, z); voi_t val2 = obj.as(); EXPECT_TRUE(val1 == val2); } struct no_def_con { no_def_con() = delete; no_def_con(int i):i(i) {} int i; MSGPACK_DEFINE(i); }; inline bool operator==(no_def_con const& lhs, no_def_con const& rhs) { return lhs.i == rhs.i; } inline bool operator!=(no_def_con const& lhs, no_def_con const& rhs) { return !(lhs == rhs); } namespace msgpack { MSGPACK_API_VERSION_NAMESPACE(MSGPACK_DEFAULT_API_NS) { namespace adaptor { template <> struct as { no_def_con operator()(msgpack::object const& o) const { if (o.type != msgpack::type::ARRAY) throw msgpack::type_error(); if (o.via.array.size != 1) throw msgpack::type_error(); return no_def_con(o.via.array.ptr[0].as()); } }; } // adaptor } // MSGPACK_API_VERSION_NAMESPACE(MSGPACK_DEFAULT_API_NS) } // msgpack TEST(MSGPACK_CPP17, optional_pack_convert_no_def_con) { std::stringstream ss; std::optional val1 = no_def_con(1); msgpack::pack(ss, val1); std::string const& str = ss.str(); msgpack::object_handle oh = msgpack::unpack(str.data(), str.size()); std::optional val2 = oh.get().as>(); EXPECT_TRUE(val1 == val2); } #endif // MSGPACK_HAS_INCLUDE() #if MSGPACK_HAS_INCLUDE() TEST(MSGPACK_CPP17, string_view_pack_convert) { std::stringstream ss; std::string s = "ABC"; std::string_view val1(s); msgpack::pack(ss, val1); std::string const& str = ss.str(); msgpack::object_handle oh; msgpack::unpack(oh, str.data(), str.size()); std::string_view val2 = oh.get().as(); EXPECT_TRUE(val1 == val2); } TEST(MSGPACK_CPP17, string_view_object) { std::string s = "ABC"; std::string_view val1(s); msgpack::object obj(val1); std::string_view val2 = obj.as(); EXPECT_TRUE(val1 == val2); } TEST(MSGPACK_CPP17, string_view_object_with_zone) { msgpack::zone z; std::string s = "ABC"; std::string_view val1(s); msgpack::object obj(val1, z); std::string_view val2 = obj.as(); EXPECT_TRUE(val1 == val2); } #endif // MSGPACK_HAS_INCLUDE() TEST(MSGPACK_CPP17, byte_pack_convert) { std::stringstream ss; std::byte val1{0xff}; msgpack::pack(ss, val1); msgpack::object_handle oh; std::string const& str = ss.str(); msgpack::unpack(oh, str.data(), str.size()); std::byte val2 = oh.get().as(); EXPECT_EQ(val1, val2); } TEST(MSGPACK_CPP17, byte_object) { std::byte val1{0x00}; msgpack::object obj(val1); std::byte val2 = obj.as(); EXPECT_EQ(val1, val2); } TEST(MSGPACK_CPP17, byte_object_with_zone) { msgpack::zone z; std::byte val1{80}; msgpack::object obj(val1, z); std::byte val2 = obj.as(); EXPECT_EQ(val1, val2); } TEST(MSGPACK_CPP17, vector_byte_pack_convert) { std::stringstream ss; std::vector val1{ std::byte{0x01}, std::byte{0x02}, std::byte{0x7f}, std::byte{0x80}, std::byte{0xff} }; msgpack::pack(ss, val1); char packed[] = { char(0xc4), char(0x05), char(0x01), char(0x02), char(0x7f), char(0x80), char(0xff) }; for (size_t i = 0; i != sizeof(packed); ++i) { std::string const& str = ss.str(); EXPECT_EQ(str[i], packed[i]); } msgpack::object_handle oh; std::string const& str = ss.str(); msgpack::unpack(oh, str.data(), str.size()); std::vector val2 = oh.get().as>(); EXPECT_EQ(val1, val2); } TEST(MSGPACK_CPP17, vector_byte_object) { std::vector val1{ std::byte{0x01}, std::byte{0x02}, std::byte{0x7f}, std::byte{0x80}, std::byte{0xff} }; // Caller need to manage val1's lifetime. The Data is not copied. msgpack::object obj(val1); std::vector val2 = obj.as>(); EXPECT_EQ(val1, val2); } TEST(MSGPACK_CPP17, vector_byte_object_with_zone) { msgpack::zone z; std::vector val1{ std::byte{0x01}, std::byte{0x02}, std::byte{0x7f}, std::byte{0x80}, std::byte{0xff} }; msgpack::object obj(val1, z); std::vector val2 = obj.as>(); EXPECT_EQ(val1, val2); } TEST(MSGPACK_CPP17, carray_byte_pack_convert) { std::stringstream ss; std::byte val1[] = { std::byte{0x01}, std::byte{0x02}, std::byte{0x7f}, std::byte{0x80}, std::byte{0xff} }; msgpack::pack(ss, val1); char packed[] = { char(0xc4), char(0x05), char(0x01), char(0x02), char(0x7f), char(0x80), char(0xff) }; for (size_t i = 0; i != sizeof(packed); ++i) { std::string const& str = ss.str(); EXPECT_EQ(str[i], packed[i]); } msgpack::object_handle oh; std::string const& str = ss.str(); msgpack::unpack(oh, str.data(), str.size()); std::byte val2[sizeof(val1)]; oh.get().convert(val2); for (size_t i = 0; i != sizeof(val1); ++i) { EXPECT_EQ(val1[i], val2[i]); } } TEST(MSGPACK_CPP17, carray_byte_object_with_zone) { msgpack::zone z; std::byte val1[] = { std::byte{0x01}, std::byte{0x02}, std::byte{0x7f}, std::byte{0x80}, std::byte{0xff} }; msgpack::object obj(val1, z); std::byte val2[sizeof(val1)]; obj.convert(val2); for (size_t i = 0; i != sizeof(val1); ++i) { EXPECT_EQ(val1[i], val2[i]); } } #endif // !defined(MSGPACK_USE_CPP03) && __cplusplus >= 201703