test_RepeatedFieldMessage.cpp 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455
  1. /*
  2. * Copyright (C) 2020 Embedded AMS B.V. - All Rights Reserved
  3. *
  4. * This file is part of Embedded Proto.
  5. *
  6. * Embedded Proto is open source software: you can redistribute it and/or
  7. * modify it under the terms of the GNU General Public License as published
  8. * by the Free Software Foundation, version 3 of the license.
  9. *
  10. * Embedded Proto is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with Embedded Proto. If not, see <https://www.gnu.org/licenses/>.
  17. *
  18. * For commercial and closed source application please visit:
  19. * <https://EmbeddedProto.com/license/>.
  20. *
  21. * Embedded AMS B.V.
  22. * Info:
  23. * info at EmbeddedProto dot com
  24. *
  25. * Postal adress:
  26. * Johan Huizingalaan 763a
  27. * 1066 VH, Amsterdam
  28. * the Netherlands
  29. */
  30. #include "gtest/gtest.h"
  31. #include <WireFormatter.h>
  32. #include <ReadBufferMock.h>
  33. #include <WriteBufferMock.h>
  34. #include <cstdint>
  35. #include <limits>
  36. // EAMS message definitions
  37. #include <repeated_fields.h>
  38. using ::testing::_;
  39. using ::testing::InSequence;
  40. using ::testing::Return;
  41. using ::testing::SetArgReferee;
  42. namespace test_EmbeddedAMS_RepeatedFieldMessage
  43. {
  44. static constexpr uint32_t Y_SIZE = 3;
  45. TEST(RepeatedFieldMessage, construction)
  46. {
  47. repeated_fields<Y_SIZE> msg;
  48. repeated_message<Y_SIZE> msg2;
  49. }
  50. TEST(RepeatedFieldMessage, serialize_empty_fields)
  51. {
  52. repeated_fields<Y_SIZE> msg;
  53. Mocks::WriteBufferMock buffer;
  54. EXPECT_CALL(buffer, push(_)).Times(0);
  55. EXPECT_CALL(buffer, push(_,_)).Times(0);
  56. EXPECT_CALL(buffer, get_available_size()).WillRepeatedly(Return(99));
  57. EXPECT_TRUE(msg.serialize(buffer));
  58. EXPECT_EQ(0, msg.serialized_size());
  59. }
  60. TEST(RepeatedFieldMessage, serialize_empty_message)
  61. {
  62. repeated_message<Y_SIZE> msg;
  63. Mocks::WriteBufferMock buffer;
  64. EXPECT_CALL(buffer, push(_)).Times(0);
  65. EXPECT_CALL(buffer, push(_,_)).Times(0);
  66. EXPECT_CALL(buffer, get_available_size()).WillRepeatedly(Return(99));
  67. EXPECT_TRUE(msg.serialize(buffer));
  68. EXPECT_EQ(0, msg.serialized_size());
  69. }
  70. TEST(RepeatedFieldMessage, serialize_array_zero_fields)
  71. {
  72. InSequence s;
  73. Mocks::WriteBufferMock buffer;
  74. repeated_fields<Y_SIZE> msg;
  75. msg.add_y(0);
  76. msg.add_y(0);
  77. msg.add_y(0);
  78. uint8_t expected[] = {0x12, 0x03, 0x00, 0x00, 0x00}; // y
  79. EXPECT_CALL(buffer, get_available_size()).Times(1).WillOnce(Return(6));
  80. for(auto e : expected)
  81. {
  82. EXPECT_CALL(buffer, push(e)).Times(1).WillOnce(Return(true));
  83. }
  84. EXPECT_TRUE(msg.serialize(buffer));
  85. }
  86. TEST(RepeatedFieldMessage, serialize_array_zero_messages)
  87. {
  88. InSequence s;
  89. Mocks::WriteBufferMock buffer;
  90. repeated_message<Y_SIZE> msg;
  91. repeated_nested_message rnm;
  92. rnm.set_u(0);
  93. rnm.set_v(0);
  94. msg.add_b(rnm);
  95. msg.add_b(rnm);
  96. msg.add_b(rnm);
  97. EXPECT_CALL(buffer, get_available_size()).Times(1).WillOnce(Return(6));
  98. EXPECT_CALL(buffer, push(0x12)).Times(1).WillOnce(Return(true));
  99. EXPECT_CALL(buffer, push(0x00)).Times(1).WillOnce(Return(true));
  100. EXPECT_CALL(buffer, push(0x12)).Times(1).WillOnce(Return(true));
  101. EXPECT_CALL(buffer, push(0x00)).Times(1).WillOnce(Return(true));
  102. EXPECT_CALL(buffer, push(0x12)).Times(1).WillOnce(Return(true));
  103. EXPECT_CALL(buffer, push(0x00)).Times(1).WillOnce(Return(true));
  104. EXPECT_TRUE(msg.serialize(buffer));
  105. }
  106. TEST(RepeatedFieldMessage, serialize_array_zero_one_zero)
  107. {
  108. InSequence s;
  109. Mocks::WriteBufferMock buffer;
  110. repeated_fields<Y_SIZE> msg;
  111. msg.add_y(0);
  112. msg.add_y(1);
  113. msg.add_y(0);
  114. uint8_t expected[] = {0x12, 0x03, 0x00, 0x01, 0x00}; // y
  115. EXPECT_CALL(buffer, get_available_size()).Times(1).WillOnce(Return(5));
  116. for(auto e : expected)
  117. {
  118. EXPECT_CALL(buffer, push(e)).Times(1).WillOnce(Return(true));
  119. }
  120. EXPECT_TRUE(msg.serialize(buffer));
  121. }
  122. TEST(RepeatedFieldMessage, serialize_array_zero_one_zero_messages)
  123. {
  124. InSequence s;
  125. Mocks::WriteBufferMock buffer;
  126. repeated_message<Y_SIZE> msg;
  127. repeated_nested_message rnm;
  128. rnm.set_u(0);
  129. rnm.set_v(0);
  130. msg.add_b(rnm);
  131. rnm.set_u(1);
  132. rnm.set_v(1);
  133. msg.add_b(rnm);
  134. rnm.set_u(0);
  135. rnm.set_v(0);
  136. msg.add_b(rnm);
  137. EXPECT_CALL(buffer, get_available_size()).Times(1).WillOnce(Return(10));
  138. EXPECT_CALL(buffer, push(0x12)).Times(1).WillOnce(Return(true));
  139. EXPECT_CALL(buffer, push(0x00)).Times(1).WillOnce(Return(true));
  140. EXPECT_CALL(buffer, push(0x12)).Times(1).WillOnce(Return(true));
  141. EXPECT_CALL(buffer, push(0x04)).Times(1).WillOnce(Return(true));
  142. EXPECT_CALL(buffer, push(0x08)).Times(1).WillOnce(Return(true));
  143. EXPECT_CALL(buffer, push(0x01)).Times(1).WillOnce(Return(true));
  144. EXPECT_CALL(buffer, push(0x10)).Times(1).WillOnce(Return(true));
  145. EXPECT_CALL(buffer, push(0x01)).Times(1).WillOnce(Return(true));
  146. EXPECT_CALL(buffer, push(0x12)).Times(1).WillOnce(Return(true));
  147. EXPECT_CALL(buffer, push(0x00)).Times(1).WillOnce(Return(true));
  148. EXPECT_TRUE(msg.serialize(buffer));
  149. }
  150. TEST(RepeatedFieldMessage, serialize_array_one)
  151. {
  152. InSequence s;
  153. Mocks::WriteBufferMock buffer;
  154. repeated_fields<Y_SIZE> msg;
  155. msg.add_y(1);
  156. msg.add_y(1);
  157. msg.add_y(1);
  158. uint8_t expected[] = {0x12, 0x03, 0x01, 0x01, 0x01}; // y
  159. EXPECT_CALL(buffer, get_available_size()).Times(1).WillOnce(Return(5));
  160. for(auto e : expected)
  161. {
  162. EXPECT_CALL(buffer, push(e)).Times(1).WillOnce(Return(true));
  163. }
  164. EXPECT_TRUE(msg.serialize(buffer));
  165. }
  166. TEST(RepeatedFieldMessage, serialize_array_max)
  167. {
  168. InSequence s;
  169. Mocks::WriteBufferMock buffer;
  170. repeated_fields<Y_SIZE> msg;
  171. msg.add_y(std::numeric_limits<uint32_t>::max());
  172. msg.add_y(std::numeric_limits<uint32_t>::max());
  173. msg.add_y(std::numeric_limits<uint32_t>::max());
  174. uint8_t expected[] = {0x12, 0x0f, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xff, 0xff, 0xff, 0xff, 0x0f}; // y
  175. EXPECT_CALL(buffer, get_available_size()).Times(1).WillOnce(Return(17));
  176. for(auto e : expected)
  177. {
  178. EXPECT_CALL(buffer, push(e)).Times(1).WillOnce(Return(true));
  179. }
  180. EXPECT_TRUE(msg.serialize(buffer));
  181. }
  182. TEST(RepeatedFieldMessage, serialize_one)
  183. {
  184. InSequence s;
  185. Mocks::WriteBufferMock buffer;
  186. repeated_fields<Y_SIZE> msg;
  187. msg.set_x(1);
  188. msg.add_y(1);
  189. msg.add_y(1);
  190. msg.add_y(1);
  191. msg.set_z(1);
  192. uint8_t expected_x[] = {0x08, 0x01}; // x
  193. for(auto e : expected_x) {
  194. EXPECT_CALL(buffer, push(e)).Times(1).WillOnce(Return(true));
  195. }
  196. uint8_t expected[] = {0x12, 0x03, 0x01, 0x01, 0x01, // y
  197. 0x18, 0x01}; // z
  198. EXPECT_CALL(buffer, get_available_size()).Times(1).WillOnce(Return(9));
  199. for(auto e : expected)
  200. {
  201. EXPECT_CALL(buffer, push(e)).Times(1).WillOnce(Return(true));
  202. }
  203. EXPECT_TRUE(msg.serialize(buffer));
  204. }
  205. TEST(RepeatedFieldMessage, serialize_max)
  206. {
  207. InSequence s;
  208. Mocks::WriteBufferMock buffer;
  209. repeated_fields<Y_SIZE> msg;
  210. msg.set_x(std::numeric_limits<uint32_t>::max());
  211. msg.add_y(std::numeric_limits<uint32_t>::max());
  212. msg.add_y(std::numeric_limits<uint32_t>::max());
  213. msg.add_y(std::numeric_limits<uint32_t>::max());
  214. msg.set_z(std::numeric_limits<uint32_t>::max());
  215. uint8_t expected_x[] = {0x08, 0xff, 0xff, 0xff, 0xff, 0x0f}; // x
  216. for(auto e : expected_x) {
  217. EXPECT_CALL(buffer, push(e)).Times(1).WillOnce(Return(true));
  218. }
  219. uint8_t expected[] = {0x12, 0x0f, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xff, 0xff, 0xff, 0xff, 0x0f, // y
  220. 0x18, 0xff, 0xff, 0xff, 0xff, 0x0f}; // z
  221. EXPECT_CALL(buffer, get_available_size()).Times(1).WillOnce(Return(17));
  222. for(auto e : expected)
  223. {
  224. EXPECT_CALL(buffer, push(e)).Times(1).WillOnce(Return(true));
  225. }
  226. EXPECT_TRUE(msg.serialize(buffer));
  227. }
  228. TEST(RepeatedFieldMessage, deserialize_empty_array)
  229. {
  230. repeated_fields<Y_SIZE> msg;
  231. Mocks::ReadBufferMock buffer;
  232. EXPECT_CALL(buffer, pop(_)).WillRepeatedly(Return(false));
  233. EXPECT_CALL(buffer, get_size()).WillRepeatedly(Return(0));
  234. EXPECT_TRUE(msg.deserialize(buffer));
  235. }
  236. TEST(RepeatedFieldMessage, deserialize_empty_message_array)
  237. {
  238. repeated_message<Y_SIZE> msg;
  239. Mocks::ReadBufferMock buffer;
  240. EXPECT_CALL(buffer, pop(_)).WillRepeatedly(Return(false));
  241. EXPECT_CALL(buffer, get_size()).WillRepeatedly(Return(0));
  242. EXPECT_TRUE(msg.deserialize(buffer));
  243. }
  244. TEST(RepeatedFieldMessage, deserialize_one)
  245. {
  246. InSequence s;
  247. repeated_fields<Y_SIZE> msg;
  248. Mocks::ReadBufferMock buffer;
  249. uint8_t referee[] = {0x08, 0x01, // x
  250. 0x12, 0x03, 0x01, 0x01, 0x01, // y
  251. 0x18, 0x01}; // z
  252. for(auto r: referee)
  253. {
  254. EXPECT_CALL(buffer, pop(_)).Times(1).WillOnce(DoAll(SetArgReferee<0>(r), Return(true)));
  255. }
  256. EXPECT_CALL(buffer, pop(_)).Times(1).WillOnce(Return(false));
  257. EXPECT_TRUE(msg.deserialize(buffer));
  258. EXPECT_EQ(1, msg.get_x());
  259. EXPECT_EQ(3, msg.get_y().get_length());
  260. EXPECT_EQ(1, msg.y(0));
  261. EXPECT_EQ(1, msg.y(1));
  262. EXPECT_EQ(1, msg.y(2));
  263. EXPECT_EQ(1, msg.get_z());
  264. }
  265. TEST(RepeatedFieldMessage, deserialize_one_message_array)
  266. {
  267. InSequence s;
  268. repeated_message<Y_SIZE> msg;
  269. Mocks::ReadBufferMock buffer;
  270. uint8_t referee[] = {0x08, 0x01, // x
  271. 0x12, 0x00, 0x12, 0x04, 0x08, 0x01, 0x10, 0x01, 0x12, 0x00, // y
  272. 0x18, 0x01}; // z
  273. for(auto r: referee)
  274. {
  275. EXPECT_CALL(buffer, pop(_)).Times(1).WillOnce(DoAll(SetArgReferee<0>(r), Return(true)));
  276. }
  277. EXPECT_CALL(buffer, pop(_)).Times(1).WillOnce(Return(false));
  278. EXPECT_TRUE(msg.deserialize(buffer));
  279. EXPECT_EQ(1, msg.get_a());
  280. EXPECT_EQ(3, msg.get_b().get_length());
  281. EXPECT_EQ(0, msg.b(0).u());
  282. EXPECT_EQ(0, msg.b(0).v());
  283. EXPECT_EQ(1, msg.b(1).u());
  284. EXPECT_EQ(1, msg.b(1).v());
  285. EXPECT_EQ(0, msg.b(2).u());
  286. EXPECT_EQ(0, msg.b(2).v());
  287. EXPECT_EQ(1, msg.get_c());
  288. }
  289. TEST(RepeatedFieldMessage, deserialize_mixed_message_array)
  290. {
  291. // I should be possible to read in the non packed data mixed with other fields. All elements
  292. // should be added to the array.
  293. InSequence s;
  294. repeated_message<Y_SIZE> msg;
  295. Mocks::ReadBufferMock buffer;
  296. uint8_t referee[] = {0x12, 0x00, // y[0]
  297. 0x08, 0x01, // x
  298. 0x12, 0x04, 0x08, 0x01, 0x10, 0x01, // y[1]
  299. 0x18, 0x01, // z
  300. 0x12, 0x00, }; // y[2]
  301. for(auto r: referee)
  302. {
  303. EXPECT_CALL(buffer, pop(_)).Times(1).WillOnce(DoAll(SetArgReferee<0>(r), Return(true)));
  304. }
  305. EXPECT_CALL(buffer, pop(_)).Times(1).WillOnce(Return(false));
  306. EXPECT_TRUE(msg.deserialize(buffer));
  307. EXPECT_EQ(1, msg.get_a());
  308. EXPECT_EQ(3, msg.get_b().get_length());
  309. EXPECT_EQ(0, msg.b(0).u());
  310. EXPECT_EQ(0, msg.b(0).v());
  311. EXPECT_EQ(1, msg.b(1).u());
  312. EXPECT_EQ(1, msg.b(1).v());
  313. EXPECT_EQ(0, msg.b(2).u());
  314. EXPECT_EQ(0, msg.b(2).v());
  315. EXPECT_EQ(1, msg.get_c());
  316. }
  317. TEST(RepeatedFieldMessage, deserialize_max)
  318. {
  319. InSequence s;
  320. repeated_fields<Y_SIZE> msg;
  321. Mocks::ReadBufferMock buffer;
  322. uint8_t referee[] = {0x08, 0xff, 0xff, 0xff, 0xff, 0x0f, // x
  323. 0x12, 0x0f, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xff, 0xff, 0xff, 0xff, 0x0f, // y
  324. 0x18, 0xff, 0xff, 0xff, 0xff, 0x0f}; // z
  325. for(auto r: referee)
  326. {
  327. EXPECT_CALL(buffer, pop(_)).Times(1).WillOnce(DoAll(SetArgReferee<0>(r), Return(true)));
  328. }
  329. EXPECT_CALL(buffer, pop(_)).Times(1).WillOnce(Return(false));
  330. EXPECT_TRUE(msg.deserialize(buffer));
  331. EXPECT_EQ(std::numeric_limits<uint32_t>::max(), msg.get_x());
  332. EXPECT_EQ(3, msg.get_y().get_length());
  333. EXPECT_EQ(std::numeric_limits<uint32_t>::max(), msg.y(0));
  334. EXPECT_EQ(std::numeric_limits<uint32_t>::max(), msg.y(1));
  335. EXPECT_EQ(std::numeric_limits<uint32_t>::max(), msg.y(2));
  336. EXPECT_EQ(std::numeric_limits<uint32_t>::max(), msg.get_z());
  337. }
  338. } // End of namespace test_EmbeddedAMS_RepeatedFieldMessage