TcpClient_test.cpp 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /*
  2. * TcpClient_test.cpp
  3. *
  4. * @build make evpp
  5. * @server bin/TcpServer_test 1234
  6. * @client bin/TcpClient_test 1234
  7. *
  8. */
  9. #include <iostream>
  10. #include "TcpClient.h"
  11. #include "htime.h"
  12. #define TEST_RECONNECT 1
  13. #define TEST_TLS 0
  14. using namespace hv;
  15. int main(int argc, char* argv[]) {
  16. if (argc < 2) {
  17. printf("Usage: %s port\n", argv[0]);
  18. return -10;
  19. }
  20. int port = atoi(argv[1]);
  21. TcpClient cli;
  22. int connfd = cli.createsocket(port);
  23. if (connfd < 0) {
  24. return -20;
  25. }
  26. printf("client connect to port %d, connfd=%d ...\n", port, connfd);
  27. cli.onConnection = [&cli](const SocketChannelPtr& channel) {
  28. std::string peeraddr = channel->peeraddr();
  29. if (channel->isConnected()) {
  30. printf("connected to %s! connfd=%d\n", peeraddr.c_str(), channel->fd());
  31. // send(time) every 3s
  32. setInterval(3000, [channel](TimerID timerID){
  33. if (channel->isConnected()) {
  34. if (channel->isWriteComplete()) {
  35. char str[DATETIME_FMT_BUFLEN] = {0};
  36. datetime_t dt = datetime_now();
  37. datetime_fmt(&dt, str);
  38. channel->write(str);
  39. }
  40. } else {
  41. killTimer(timerID);
  42. }
  43. });
  44. } else {
  45. printf("disconnected to %s! connfd=%d\n", peeraddr.c_str(), channel->fd());
  46. }
  47. if (cli.isReconnect()) {
  48. printf("reconnect cnt=%d, delay=%d\n", cli.reconn_setting->cur_retry_cnt, cli.reconn_setting->cur_delay);
  49. }
  50. };
  51. cli.onMessage = [](const SocketChannelPtr& channel, Buffer* buf) {
  52. printf("< %.*s\n", (int)buf->size(), (char*)buf->data());
  53. };
  54. #if TEST_RECONNECT
  55. // reconnect: 1,2,4,8,10,10,10...
  56. reconn_setting_t reconn;
  57. reconn_setting_init(&reconn);
  58. reconn.min_delay = 1000;
  59. reconn.max_delay = 10000;
  60. reconn.delay_policy = 2;
  61. cli.setReconnect(&reconn);
  62. #endif
  63. #if TEST_TLS
  64. cli.withTLS();
  65. #endif
  66. cli.start();
  67. std::string str;
  68. while (std::getline(std::cin, str)) {
  69. if (str == "close") {
  70. cli.closesocket();
  71. } else if (str == "start") {
  72. cli.start();
  73. } else if (str == "stop") {
  74. cli.stop();
  75. break;
  76. } else {
  77. if (!cli.isConnected()) break;
  78. cli.send(str);
  79. }
  80. }
  81. return 0;
  82. }