message.cpp 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. #define CATCH_CONFIG_MAIN
  2. #include <catch.hpp>
  3. #include <zmq.hpp>
  4. #if defined(ZMQ_CPP11)
  5. static_assert(!std::is_copy_constructible<zmq::message_t>::value,
  6. "message_t should not be copy-constructible");
  7. static_assert(!std::is_copy_assignable<zmq::message_t>::value,
  8. "message_t should not be copy-assignable");
  9. #endif
  10. #if (__cplusplus >= 201703L)
  11. static_assert(std::is_nothrow_swappable<zmq::message_t>::value,
  12. "message_t should be nothrow swappable");
  13. #endif
  14. TEST_CASE("message default constructed", "[message]")
  15. {
  16. const zmq::message_t message;
  17. CHECK(0u == message.size());
  18. CHECK(message.empty());
  19. }
  20. #ifdef ZMQ_CPP11
  21. TEST_CASE("message swap", "[message]")
  22. {
  23. const std::string data = "foo";
  24. zmq::message_t message1;
  25. zmq::message_t message2(data.data(), data.size());
  26. using std::swap;
  27. swap(message1, message2);
  28. CHECK(message1.size() == data.size());
  29. CHECK(message2.size() == 0);
  30. swap(message1, message2);
  31. CHECK(message1.size() == 0);
  32. CHECK(message2.size() == data.size());
  33. }
  34. #endif
  35. namespace
  36. {
  37. const char *const data = "Hi";
  38. }
  39. TEST_CASE("message constructor with iterators", "[message]")
  40. {
  41. const std::string hi(data);
  42. const zmq::message_t hi_msg(hi.begin(), hi.end());
  43. CHECK(2u == hi_msg.size());
  44. CHECK(0 == memcmp(data, hi_msg.data(), 2));
  45. }
  46. TEST_CASE("message constructor with size", "[message]")
  47. {
  48. const zmq::message_t msg(5);
  49. CHECK(msg.size() == 5);
  50. }
  51. TEST_CASE("message constructor with buffer and size", "[message]")
  52. {
  53. const std::string hi(data);
  54. const zmq::message_t hi_msg(hi.data(), hi.size());
  55. CHECK(2u == hi_msg.size());
  56. CHECK(0 == memcmp(data, hi_msg.data(), 2));
  57. }
  58. TEST_CASE("message constructor with char array", "[message]")
  59. {
  60. const zmq::message_t hi_msg(data, strlen(data));
  61. CHECK(2u == hi_msg.size());
  62. CHECK(0 == memcmp(data, hi_msg.data(), 2));
  63. }
  64. #if defined(ZMQ_BUILD_DRAFT_API) && defined(ZMQ_CPP11)
  65. TEST_CASE("message constructor with container", "[message]")
  66. {
  67. const std::string hi(data);
  68. zmq::message_t hi_msg(hi);
  69. CHECK(2u == hi_msg.size());
  70. CHECK(0 == memcmp(data, hi_msg.data(), 2));
  71. }
  72. #endif
  73. #ifdef ZMQ_HAS_RVALUE_REFS
  74. TEST_CASE("message move constructor", "[message]")
  75. {
  76. zmq::message_t hi_msg(zmq::message_t(data, strlen(data)));
  77. }
  78. TEST_CASE("message assign move empty before", "[message]")
  79. {
  80. zmq::message_t hi_msg;
  81. hi_msg = zmq::message_t(data, strlen(data));
  82. CHECK(2u == hi_msg.size());
  83. CHECK(0 == memcmp(data, hi_msg.data(), 2));
  84. }
  85. TEST_CASE("message assign move empty after", "[message]")
  86. {
  87. zmq::message_t hi_msg(data, strlen(data));
  88. CHECK(!hi_msg.empty());
  89. hi_msg = zmq::message_t();
  90. CHECK(0u == hi_msg.size());
  91. CHECK(hi_msg.empty());
  92. }
  93. TEST_CASE("message assign move empty before and after", "[message]")
  94. {
  95. zmq::message_t hi_msg;
  96. hi_msg = zmq::message_t();
  97. CHECK(0u == hi_msg.size());
  98. }
  99. #endif
  100. TEST_CASE("message equality self", "[message]")
  101. {
  102. const zmq::message_t hi_msg(data, strlen(data));
  103. CHECK(hi_msg == hi_msg);
  104. }
  105. TEST_CASE("message equality equal", "[message]")
  106. {
  107. const zmq::message_t hi_msg_a(data, strlen(data));
  108. const zmq::message_t hi_msg_b(data, strlen(data));
  109. CHECK(hi_msg_a == hi_msg_b);
  110. }
  111. TEST_CASE("message equality equal empty", "[message]")
  112. {
  113. const zmq::message_t msg_a;
  114. const zmq::message_t msg_b;
  115. CHECK(msg_a == msg_b);
  116. }
  117. TEST_CASE("message equality non equal", "[message]")
  118. {
  119. const zmq::message_t msg_a("Hi", 2);
  120. const zmq::message_t msg_b("Hello", 5);
  121. CHECK(msg_a != msg_b);
  122. }
  123. TEST_CASE("message equality non equal rhs empty", "[message]")
  124. {
  125. const zmq::message_t msg_a("Hi", 2);
  126. const zmq::message_t msg_b;
  127. CHECK(msg_a != msg_b);
  128. }
  129. TEST_CASE("message equality non equal lhs empty", "[message]")
  130. {
  131. const zmq::message_t msg_a;
  132. const zmq::message_t msg_b("Hi", 2);
  133. CHECK(msg_a != msg_b);
  134. }
  135. TEST_CASE("message to string", "[message]")
  136. {
  137. const zmq::message_t a;
  138. const zmq::message_t b("Foo", 3);
  139. CHECK(a.to_string() == "");
  140. CHECK(b.to_string() == "Foo");
  141. #if CPPZMQ_HAS_STRING_VIEW
  142. CHECK(a.to_string_view() == "");
  143. CHECK(b.to_string_view() == "Foo");
  144. #endif
  145. }
  146. #if defined(ZMQ_BUILD_DRAFT_API) && ZMQ_VERSION >= ZMQ_MAKE_VERSION(4, 2, 0)
  147. TEST_CASE("message routing id persists", "[message]")
  148. {
  149. zmq::message_t msg;
  150. msg.set_routing_id(123);
  151. CHECK(123u == msg.routing_id());
  152. }
  153. TEST_CASE("message group persists", "[message]")
  154. {
  155. zmq::message_t msg;
  156. msg.set_group("mygroup");
  157. CHECK(std::string(msg.group()) == "mygroup");
  158. }
  159. #endif
  160. #if ZMQ_VERSION >= ZMQ_MAKE_VERSION(3, 2, 0)
  161. TEST_CASE("message is not shared", "[message]")
  162. {
  163. zmq::message_t msg;
  164. CHECK(msg.get(ZMQ_SHARED) == 0);
  165. }
  166. TEST_CASE("message is shared", "[message]")
  167. {
  168. size_t msg_sz = 1024; // large enough to be a type_lmsg
  169. zmq::message_t msg1(msg_sz);
  170. zmq::message_t msg2;
  171. msg2.copy(msg1);
  172. CHECK(msg1.get(ZMQ_SHARED) == 1);
  173. CHECK(msg2.get(ZMQ_SHARED) == 1);
  174. CHECK(msg1.size() == msg_sz);
  175. CHECK(msg2.size() == msg_sz);
  176. }
  177. TEST_CASE("message move is not shared", "[message]")
  178. {
  179. size_t msg_sz = 1024; // large enough to be a type_lmsg
  180. zmq::message_t msg1(msg_sz);
  181. zmq::message_t msg2;
  182. msg2.move(msg1);
  183. CHECK(msg1.get(ZMQ_SHARED) == 0);
  184. CHECK(msg2.get(ZMQ_SHARED) == 0);
  185. CHECK(msg2.size() == msg_sz);
  186. CHECK(msg1.size() == 0);
  187. }
  188. #endif