NetworkTests.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504
  1. #define IMPORT_CORE
  2. #include <core/Logger.h>
  3. #include <core/Utility.h>
  4. #include <string.h>
  5. #include "../Tests.h"
  6. #include "../src/ErrorSimulator.h"
  7. #include "core/Network.h"
  8. #define TEST_READ(Type, type, value) \
  9. { \
  10. type u; \
  11. TEST_FALSE(readInPacket##Type(&in, &u)); \
  12. TEST_TRUE(u == value); \
  13. }
  14. static void testWriteRead(void) {
  15. OutPacket out;
  16. initOutPacket(&out);
  17. writeOutPacketU8(&out, 200);
  18. writeOutPacketU16(&out, 6656);
  19. writeOutPacketU32(&out, 348923689);
  20. writeOutPacketI8(&out, 90);
  21. writeOutPacketI8(&out, -35);
  22. writeOutPacketI16(&out, 843);
  23. writeOutPacketI16(&out, -8961);
  24. writeOutPacketI32(&out, 100430199);
  25. writeOutPacketI32(&out, -534534);
  26. writeOutPacketFloat(&out, 64564.5346f);
  27. const char s[] = "This is Great";
  28. writeOutPacketString(&out, s);
  29. InPacket in;
  30. initInPacket(&in, out.data.buffer, out.data.size);
  31. TEST_READ(U8, u8, 200)
  32. TEST_READ(U16, u16, 6656)
  33. TEST_READ(U32, u32, 348923689)
  34. TEST_READ(I8, i8, 90)
  35. TEST_READ(I8, i8, -35)
  36. TEST_READ(I16, i16, 843)
  37. TEST_READ(I16, i16, -8961)
  38. TEST_READ(I32, i32, 100430199)
  39. TEST_READ(I32, i32, -534534)
  40. float f;
  41. TEST_FALSE(readInPacketFloat(&in, &f));
  42. TEST_FLOAT(64564.5346f, f, 0.00001f);
  43. char buffer[256];
  44. size_t n = readInPacketString(&in, buffer, sizeof(buffer));
  45. TEST_SIZE(14, n);
  46. TEST_STRING(s, buffer);
  47. TEST_TRUE(readInPacketU8(&in, &(u8){0}));
  48. TEST_TRUE(readInPacketU16(&in, &(u16){0}));
  49. TEST_TRUE(readInPacketU32(&in, &(u32){0}));
  50. TEST_TRUE(readInPacketI8(&in, &(i8){0}));
  51. TEST_TRUE(readInPacketI16(&in, &(i16){0}));
  52. TEST_TRUE(readInPacketI32(&in, &(i32){0}));
  53. TEST_TRUE(readInPacketFloat(&in, &(float){0}));
  54. TEST_SIZE(0, readInPacketString(&in, nullptr, 0));
  55. TEST_SIZE(0, readInPacketString(&in, buffer, sizeof(buffer)));
  56. destroyOutPacket(&out);
  57. }
  58. static void testTooShortBuffer(void) {
  59. OutPacket out;
  60. initOutPacket(&out);
  61. writeOutPacketString(&out, "This is Great");
  62. writeOutPacketString(&out, "Well hoho");
  63. InPacket in;
  64. initInPacket(&in, out.data.buffer, out.data.size);
  65. char buffer[8];
  66. size_t n = readInPacketString(&in, buffer, sizeof(buffer));
  67. TEST_SIZE(14, n);
  68. TEST_STRING("This is", buffer);
  69. char buffer2[6];
  70. size_t n2 = readInPacketString(&in, buffer2, sizeof(buffer2));
  71. TEST_SIZE(10, n2);
  72. TEST_STRING("Well ", buffer2);
  73. destroyOutPacket(&out);
  74. }
  75. typedef struct {
  76. u8 a;
  77. u8 b;
  78. } PacketTest;
  79. static void testBinaryData(void) {
  80. OutPacket out;
  81. initOutPacket(&out);
  82. PacketTest data = {56, 3};
  83. writeOutPacket(&out, &data, sizeof(data));
  84. InPacket in;
  85. initInPacket(&in, out.data.buffer, out.data.size);
  86. PacketTest inData;
  87. TEST_FALSE(readInPacket(&in, &inData, sizeof(inData)));
  88. TEST_TRUE(memcmp(&inData, &data, sizeof(inData)) == 0);
  89. destroyOutPacket(&out);
  90. }
  91. static void testShortString(void) {
  92. OutPacket out;
  93. initOutPacket(&out);
  94. writeOutPacketU16(&out, 200);
  95. writeOutPacketU16(&out, 65535);
  96. InPacket in;
  97. initInPacket(&in, out.data.buffer, out.data.size);
  98. char buffer[256];
  99. size_t n = readInPacketString(&in, buffer, sizeof(buffer));
  100. TEST_SIZE(200, n);
  101. TEST_STRING("", buffer);
  102. destroyOutPacket(&out);
  103. }
  104. static void tickClientN(int ticks) {
  105. for(int i = 0; i < ticks; i++) {
  106. tickClient();
  107. }
  108. }
  109. static void tick(int ticks) {
  110. for(int i = 0; i < ticks; i++) {
  111. tickClient();
  112. tickServer();
  113. }
  114. }
  115. static bool clientConnected = false;
  116. static bool clientDisconnected = false;
  117. static bool clientPackage = false;
  118. static int packageCounter = 0;
  119. static bool serverConnected = false;
  120. static bool serverDisconnect = false;
  121. static u8 data1 = 0;
  122. static u16 data2 = 0;
  123. static u32 data3 = 0;
  124. static i8 data4 = 0;
  125. static i16 data5 = 0;
  126. static i32 data6 = 0;
  127. static i8 data7 = 0;
  128. static i16 data8 = 0;
  129. static i32 data9 = 0;
  130. static char data10[20];
  131. static float data11 = 0.0f;
  132. static void onServerConnect(Client) {
  133. serverConnected = true;
  134. }
  135. static void onServerDisconnect(Client) {
  136. serverDisconnect = true;
  137. }
  138. static void onServerPacket(Client client, InPacket* in) {
  139. TEST_FALSE(readInPacketU8(in, &data1));
  140. TEST_FALSE(readInPacketU16(in, &data2));
  141. TEST_FALSE(readInPacketU32(in, &data3));
  142. TEST_FALSE(readInPacketI8(in, &data4));
  143. TEST_FALSE(readInPacketI16(in, &data5));
  144. TEST_FALSE(readInPacketI32(in, &data6));
  145. TEST_FALSE(readInPacketI8(in, &data7));
  146. TEST_FALSE(readInPacketI16(in, &data8));
  147. TEST_FALSE(readInPacketI32(in, &data9));
  148. TEST_SIZE(9, readInPacketString(in, data10, sizeof(data10)));
  149. TEST_FALSE(readInPacketFloat(in, &data11));
  150. OutPacket out;
  151. initOutPacket(&out);
  152. if(packageCounter == 0) {
  153. sendServerPacket(client, &out, PACKET_RELIABLE);
  154. } else if(packageCounter == 1) {
  155. sendServerPacket(client, &out, PACKET_SEQUENCED);
  156. } else if(packageCounter == 2) {
  157. sendServerPacket(client, &out, PACKET_UNSEQUENCED);
  158. }
  159. destroyOutPacket(&out);
  160. packageCounter++;
  161. }
  162. static void onClientConnect() {
  163. clientConnected = true;
  164. }
  165. static void onClientDisconnect() {
  166. clientDisconnected = true;
  167. }
  168. static void onClientPacket(InPacket*) {
  169. clientPackage = true;
  170. }
  171. static void testConnect(PacketSendMode mode) {
  172. clientConnected = false;
  173. clientDisconnected = false;
  174. clientPackage = false;
  175. serverConnected = false;
  176. serverDisconnect = false;
  177. data1 = 0;
  178. data2 = 0;
  179. data3 = 0;
  180. data4 = 0;
  181. data5 = 0;
  182. data6 = 0;
  183. data7 = 0;
  184. data8 = 0;
  185. data9 = 0;
  186. *data10 = '\0';
  187. data11 = 0.0f;
  188. resetServerHandler();
  189. setServerConnectHandler(onServerConnect);
  190. setServerDisconnectHandler(onServerDisconnect);
  191. setServerPacketHandler(onServerPacket);
  192. resetClientHandler();
  193. setClientConnectHandler(onClientConnect);
  194. setClientDisconnectHandler(onClientDisconnect);
  195. setClientPacketHandler(onClientPacket);
  196. if(!TEST_FALSE(startServer(54321, 5))) {
  197. return;
  198. } else if(!TEST_FALSE(startClient())) {
  199. return;
  200. } else if(!TEST_FALSE(connectClient("127.0.0.1", 54321, 90))) {
  201. return;
  202. }
  203. TEST_FALSE(isClientConnected());
  204. TEST_TRUE(isClientConnecting());
  205. tick(100);
  206. TEST_TRUE(clientConnected);
  207. TEST_TRUE(isClientConnected());
  208. TEST_FALSE(isClientConnecting());
  209. OutPacket out;
  210. initOutPacket(&out);
  211. writeOutPacketU8(&out, 0xF1);
  212. writeOutPacketU16(&out, 0xF123);
  213. writeOutPacketU32(&out, 0xF1234567);
  214. writeOutPacketI8(&out, -0x71);
  215. writeOutPacketI16(&out, -0x7123);
  216. writeOutPacketI32(&out, -0x71234567);
  217. writeOutPacketI8(&out, 0x71);
  218. writeOutPacketI16(&out, 0x7123);
  219. writeOutPacketI32(&out, 0x71234567);
  220. const char s[] = "Hi there";
  221. writeOutPacketString(&out, s);
  222. writeOutPacketFloat(&out, 252345.983f);
  223. sendClientPacket(&out, mode);
  224. destroyOutPacket(&out);
  225. tick(100);
  226. TEST_TRUE(clientPackage);
  227. TEST_TRUE(serverConnected);
  228. TEST_U64(0xF1, data1);
  229. TEST_U64(0xF123, data2);
  230. TEST_U64(0xF1234567, data3);
  231. TEST_I64(-0x71, data4);
  232. TEST_I64(-0x7123, data5);
  233. TEST_I64(-0x71234567, data6);
  234. TEST_I64(0x71, data7);
  235. TEST_I64(0x7123, data8);
  236. TEST_I64(0x71234567, data9);
  237. TEST_STRING(s, data10);
  238. TEST_FLOAT(252345.983f, data11, 0.01f);
  239. disconnectClient(90);
  240. TEST_FALSE(isClientConnected());
  241. TEST_FALSE(isClientConnecting());
  242. tick(100);
  243. TEST_TRUE(clientDisconnected);
  244. TEST_TRUE(serverDisconnect);
  245. stopClient();
  246. stopServer();
  247. }
  248. static bool disconnected = false;
  249. static void testStopDisconnect(void) {
  250. disconnected = true;
  251. }
  252. static void testDisconnect(void) {
  253. disconnected = false;
  254. resetClientHandler();
  255. setClientDisconnectHandler(testStopDisconnect);
  256. if(!TEST_FALSE(startClient())) {
  257. return;
  258. } else if(!TEST_FALSE(connectClient("127.0.0.1", 54321, 90))) {
  259. return;
  260. }
  261. TEST_FALSE(isClientConnected());
  262. TEST_TRUE(isClientConnecting());
  263. disconnectClient(50);
  264. tickClientN(100);
  265. TEST_FALSE(isClientConnected());
  266. TEST_FALSE(isClientConnecting());
  267. TEST_TRUE(disconnected);
  268. stopClient();
  269. }
  270. static void testStop(void) {
  271. disconnected = false;
  272. resetClientHandler();
  273. setClientDisconnectHandler(testStopDisconnect);
  274. if(!TEST_FALSE(startClient())) {
  275. return;
  276. } else if(!TEST_FALSE(connectClient("127.0.0.1", 54321, 90))) {
  277. return;
  278. }
  279. TEST_FALSE(isClientConnected());
  280. TEST_TRUE(isClientConnecting());
  281. stopClient();
  282. TEST_FALSE(isClientConnected());
  283. TEST_FALSE(isClientConnecting());
  284. TEST_TRUE(disconnected);
  285. }
  286. static void testClientStartFails(void) {
  287. TEST_FALSE(startClient());
  288. logLevel = LOG_NONE;
  289. TEST_TRUE(startClient());
  290. stopClient();
  291. #ifdef ERROR_SIMULATOR
  292. failCounter = 0;
  293. TEST_TRUE(startClient());
  294. failCounter = 1;
  295. TEST_TRUE(startClient());
  296. failCounter = -1;
  297. #endif
  298. logLevel = LOG_DEBUG;
  299. }
  300. static void testClientConnectionFails(void) {
  301. resetClientHandler();
  302. logLevel = LOG_NONE;
  303. TEST_TRUE(connectClient("", 54321, 100));
  304. TEST_FALSE(startClient());
  305. #ifdef ERROR_SIMULATOR
  306. failCounter = 0;
  307. TEST_TRUE(connectClient("", 54321, 100));
  308. failCounter = -1;
  309. #endif
  310. TEST_FALSE(connectClient("", 54321, 100));
  311. TEST_TRUE(connectClient("", 54321, 100));
  312. logLevel = LOG_DEBUG;
  313. tickClientN(100);
  314. stopClient();
  315. }
  316. static void testInvalidClientAccess(void) {
  317. disconnectClient(0);
  318. sendClientPacket(nullptr, 0);
  319. tickClient();
  320. }
  321. static void testServerStartFails(void) {
  322. logLevel = LOG_NONE;
  323. TEST_TRUE(startServer(54321, 0));
  324. #ifdef ERROR_SIMULATOR
  325. failCounter = 0;
  326. TEST_TRUE(startServer(54321, 5));
  327. failCounter = 1;
  328. TEST_TRUE(startServer(54321, 5));
  329. failCounter = -1;
  330. #endif
  331. TEST_FALSE(startServer(54321, 5));
  332. TEST_TRUE(startServer(54321, 5));
  333. logLevel = LOG_DEBUG;
  334. stopServer();
  335. }
  336. static void testServerClosesOnConnected(void) {
  337. clientDisconnected = false;
  338. TEST_FALSE(startServer(54321, 5));
  339. TEST_FALSE(startClient());
  340. setClientDisconnectHandler(onClientDisconnect);
  341. TEST_FALSE(connectClient("127.0.0.1", 54321, 50));
  342. tick(100);
  343. TEST_TRUE(isClientConnected());
  344. stopServer();
  345. setClientTimeout(500, 500, 500);
  346. for(int i = 0; i < 500 && isClientConnected(); i++) {
  347. tickClient();
  348. sleepNanos(10000000);
  349. }
  350. TEST_FALSE(isClientConnected());
  351. TEST_TRUE(clientDisconnected);
  352. stopClient();
  353. }
  354. static Client clientId = 0;
  355. static void onConnectSetClient(Client client) {
  356. clientId = client;
  357. }
  358. static void testServerDisconnectsClient(void) {
  359. clientDisconnected = false;
  360. TEST_FALSE(startServer(54321, 5));
  361. TEST_FALSE(startClient());
  362. setClientDisconnectHandler(onClientDisconnect);
  363. setServerConnectHandler(onConnectSetClient);
  364. TEST_FALSE(connectClient("127.0.0.1", 54321, 50));
  365. tick(100);
  366. TEST_TRUE(isClientConnected());
  367. disconnectServerClient(clientId);
  368. for(int i = 0; i < 500 && isClientConnected(); i++) {
  369. tickClient();
  370. tickServer();
  371. sleepNanos(10000000);
  372. }
  373. TEST_FALSE(isClientConnected());
  374. TEST_TRUE(clientDisconnected);
  375. stopClient();
  376. stopServer();
  377. }
  378. static void onConnectSetTimeout(Client client) {
  379. setServerTimeout(client, 500, 500, 500);
  380. }
  381. static void testClientClosesOnConnected(void) {
  382. serverDisconnect = false;
  383. TEST_FALSE(startServer(54321, 5));
  384. TEST_FALSE(startClient());
  385. setServerDisconnectHandler(onServerDisconnect);
  386. setServerConnectHandler(onConnectSetTimeout);
  387. TEST_FALSE(connectClient("127.0.0.1", 54321, 50));
  388. tick(100);
  389. TEST_TRUE(isClientConnected());
  390. #ifdef ERROR_SIMULATOR
  391. failCounter = 0;
  392. #endif
  393. stopClient();
  394. #ifdef ERROR_SIMULATOR
  395. failCounter = -1;
  396. #endif
  397. for(int i = 0; i < 500 && !serverDisconnect; i++) {
  398. tickServer();
  399. sleepNanos(10000000);
  400. }
  401. TEST_TRUE(serverDisconnect);
  402. stopServer();
  403. }
  404. static void testInvalidServerAccess(void) {
  405. tickServer();
  406. sendServerPacket(0, nullptr, 0);
  407. setServerTimeout(0, 500, 500, 500);
  408. disconnectServerClient(0);
  409. }
  410. static void testDummyCallbacks(void) {
  411. resetClientHandler();
  412. resetServerHandler();
  413. TEST_FALSE(startServer(54321, 5));
  414. TEST_FALSE(startClient());
  415. TEST_FALSE(connectClient("127.0.0.1", 54321, 50));
  416. tick(100);
  417. TEST_TRUE(isClientConnected());
  418. OutPacket out;
  419. initOutPacket(&out);
  420. sendServerPacketBroadcast(&out, PACKET_RELIABLE);
  421. sendClientPacket(&out, PACKET_RELIABLE);
  422. tick(100);
  423. destroyOutPacket(&out);
  424. stopClient();
  425. stopServer();
  426. }
  427. void testNetwork(void) {
  428. testWriteRead();
  429. testTooShortBuffer();
  430. testBinaryData();
  431. testShortString();
  432. testConnect(PACKET_UNSEQUENCED);
  433. testConnect(PACKET_SEQUENCED);
  434. testConnect(PACKET_RELIABLE);
  435. testDisconnect();
  436. testStop();
  437. testClientStartFails();
  438. testClientConnectionFails();
  439. testInvalidClientAccess();
  440. testServerStartFails();
  441. testServerClosesOnConnected();
  442. testServerDisconnectsClient();
  443. testClientClosesOnConnected();
  444. testInvalidServerAccess();
  445. testDummyCallbacks();
  446. }