websocket_client_test.cpp 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. /*
  2. * websocket client
  3. *
  4. * @build make examples
  5. * @server bin/websocket_server_test 8888
  6. * @client bin/websocket_client_test ws://127.0.0.1:8888/test
  7. * @clients bin/websocket_client_test ws://127.0.0.1:8888/test 100
  8. * @js html/websocket_client.html
  9. *
  10. */
  11. #include "WebSocketClient.h"
  12. using namespace hv;
  13. class MyWebSocketClient : public WebSocketClient {
  14. public:
  15. MyWebSocketClient(EventLoopPtr loop = NULL) : WebSocketClient(loop) {}
  16. ~MyWebSocketClient() {}
  17. int connect(const char* url) {
  18. // set callbacks
  19. onopen = [this]() {
  20. const HttpResponsePtr& resp = getHttpResponse();
  21. printf("onopen\n%s\n", resp->body.c_str());
  22. // printf("response:\n%s\n", resp->Dump(true, true).c_str());
  23. };
  24. onmessage = [this](const std::string& msg) {
  25. printf("onmessage(type=%s len=%d): %.*s\n", opcode() == WS_OPCODE_TEXT ? "text" : "binary",
  26. (int)msg.size(), (int)msg.size(), msg.data());
  27. };
  28. onclose = []() {
  29. printf("onclose\n");
  30. };
  31. // reconnect: 1,2,4,8,10,10,10...
  32. reconn_setting_t reconn;
  33. reconn_setting_init(&reconn);
  34. reconn.min_delay = 1000;
  35. reconn.max_delay = 10000;
  36. reconn.delay_policy = 2;
  37. setReconnect(&reconn);
  38. /*
  39. auto req = std::make_shared<HttpRequest>();
  40. req->method = HTTP_POST;
  41. req->headers["Origin"] = "http://example.com";
  42. req->json["app_id"] = "123456";
  43. req->json["app_secret"] = "abcdefg";
  44. printf("request:\n%s\n", req->Dump(true, true).c_str());
  45. setHttpRequest(req);
  46. */
  47. http_headers headers;
  48. headers["Origin"] = "http://example.com/";
  49. return open(url, headers);
  50. };
  51. };
  52. typedef std::shared_ptr<MyWebSocketClient> MyWebSocketClientPtr;
  53. int TestMultiClientsRunInOneEventLoop(const char* url, int nclients) {
  54. auto loop_thread = std::make_shared<EventLoopThread>();
  55. loop_thread->start();
  56. std::map<int, MyWebSocketClientPtr> clients;
  57. for (int i = 0; i < nclients; ++i) {
  58. MyWebSocketClient* client = new MyWebSocketClient(loop_thread->loop());
  59. client->connect(url);
  60. clients[i] = MyWebSocketClientPtr(client);
  61. }
  62. // press Enter to stop
  63. while (getchar() != '\n');
  64. loop_thread->stop();
  65. loop_thread->join();
  66. return 0;
  67. }
  68. int main(int argc, char** argv) {
  69. if (argc < 2) {
  70. printf("Usage: %s url\n", argv[0]);
  71. return -10;
  72. }
  73. const char* url = argv[1];
  74. int nclients = 0;
  75. if (argc > 2) {
  76. nclients = atoi(argv[2]);
  77. }
  78. if (nclients > 0) {
  79. return TestMultiClientsRunInOneEventLoop(url, nclients);
  80. }
  81. MyWebSocketClient ws;
  82. ws.connect(url);
  83. std::string str;
  84. while (std::getline(std::cin, str)) {
  85. if (str == "close") {
  86. ws.close();
  87. } else if (str == "open") {
  88. ws.connect(url);
  89. } else if (str == "stop") {
  90. ws.stop();
  91. break;
  92. } else {
  93. if (!ws.isConnected()) break;
  94. ws.send(str);
  95. }
  96. }
  97. return 0;
  98. }