test_lwip_apps.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. #include "freertos/FreeRTOS.h"
  2. #include "freertos/event_groups.h"
  3. #include "test_utils.h"
  4. #include "unity.h"
  5. #include "lwip/inet.h"
  6. #include "lwip/netdb.h"
  7. #include "lwip/sockets.h"
  8. #include "ping/ping_sock.h"
  9. #define ETH_PING_END_BIT BIT(1)
  10. #define ETH_PING_DURATION_MS (5000)
  11. #define ETH_PING_END_TIMEOUT_MS (ETH_PING_DURATION_MS * 2)
  12. #define TEST_ICMP_DESTINATION_DOMAIN_NAME "127.0.0.1"
  13. static void test_on_ping_success(esp_ping_handle_t hdl, void *args)
  14. {
  15. uint8_t ttl;
  16. uint16_t seqno;
  17. uint32_t elapsed_time, recv_len;
  18. ip_addr_t target_addr;
  19. esp_ping_get_profile(hdl, ESP_PING_PROF_SEQNO, &seqno, sizeof(seqno));
  20. esp_ping_get_profile(hdl, ESP_PING_PROF_TTL, &ttl, sizeof(ttl));
  21. esp_ping_get_profile(hdl, ESP_PING_PROF_IPADDR, &target_addr, sizeof(target_addr));
  22. esp_ping_get_profile(hdl, ESP_PING_PROF_SIZE, &recv_len, sizeof(recv_len));
  23. esp_ping_get_profile(hdl, ESP_PING_PROF_TIMEGAP, &elapsed_time, sizeof(elapsed_time));
  24. printf("%d bytes from %s icmp_seq=%d ttl=%d time=%d ms\n",
  25. recv_len, inet_ntoa(target_addr.u_addr.ip4), seqno, ttl, elapsed_time);
  26. }
  27. static void test_on_ping_timeout(esp_ping_handle_t hdl, void *args)
  28. {
  29. uint16_t seqno;
  30. ip_addr_t target_addr;
  31. esp_ping_get_profile(hdl, ESP_PING_PROF_SEQNO, &seqno, sizeof(seqno));
  32. esp_ping_get_profile(hdl, ESP_PING_PROF_IPADDR, &target_addr, sizeof(target_addr));
  33. printf("From %s icmp_seq=%d timeout\n", inet_ntoa(target_addr.u_addr.ip4), seqno);
  34. }
  35. static void test_on_ping_end(esp_ping_handle_t hdl, void *args)
  36. {
  37. EventGroupHandle_t eth_event_group = (EventGroupHandle_t)args;
  38. uint32_t transmitted;
  39. uint32_t received;
  40. uint32_t total_time_ms;
  41. esp_ping_get_profile(hdl, ESP_PING_PROF_REQUEST, &transmitted, sizeof(transmitted));
  42. esp_ping_get_profile(hdl, ESP_PING_PROF_REPLY, &received, sizeof(received));
  43. esp_ping_get_profile(hdl, ESP_PING_PROF_DURATION, &total_time_ms, sizeof(total_time_ms));
  44. printf("%d packets transmitted, %d received, time %dms\n", transmitted, received, total_time_ms);
  45. if (transmitted == received) {
  46. xEventGroupSetBits(eth_event_group, ETH_PING_END_BIT);
  47. }
  48. }
  49. TEST_CASE("localhost ping test", "[lwip]")
  50. {
  51. EventBits_t bits;
  52. EventGroupHandle_t eth_event_group = xEventGroupCreate();
  53. TEST_ASSERT(eth_event_group != NULL);
  54. test_case_uses_tcpip();
  55. // Parse IP address: Destination is a localhost address, so we don't need any interface (esp-netif/driver)
  56. ip_addr_t target_addr;
  57. struct addrinfo hint;
  58. struct addrinfo *res = NULL;
  59. memset(&hint, 0, sizeof(hint));
  60. memset(&target_addr, 0, sizeof(target_addr));
  61. /* convert URL to IP */
  62. TEST_ASSERT(getaddrinfo(TEST_ICMP_DESTINATION_DOMAIN_NAME, NULL, &hint, &res) == 0);
  63. struct in_addr addr4 = ((struct sockaddr_in *)(res->ai_addr))->sin_addr;
  64. inet_addr_to_ip4addr(ip_2_ip4(&target_addr), &addr4);
  65. freeaddrinfo(res);
  66. esp_ping_config_t ping_config = ESP_PING_DEFAULT_CONFIG();
  67. ping_config.timeout_ms = 2000;
  68. ping_config.target_addr = target_addr;
  69. ping_config.count = 0; // ping in infinite mode
  70. /* set callback functions */
  71. esp_ping_callbacks_t cbs;
  72. cbs.on_ping_success = test_on_ping_success;
  73. cbs.on_ping_timeout = test_on_ping_timeout;
  74. cbs.on_ping_end = test_on_ping_end;
  75. cbs.cb_args = eth_event_group;
  76. esp_ping_handle_t ping;
  77. TEST_ESP_OK(esp_ping_new_session(&ping_config, &cbs, &ping));
  78. /* start ping */
  79. TEST_ESP_OK(esp_ping_start(ping));
  80. /* ping for a while */
  81. vTaskDelay(pdMS_TO_TICKS(ETH_PING_DURATION_MS));
  82. /* stop ping */
  83. TEST_ESP_OK(esp_ping_stop(ping));
  84. /* wait for end of ping */
  85. bits = xEventGroupWaitBits(eth_event_group, ETH_PING_END_BIT, true, true, pdMS_TO_TICKS(ETH_PING_END_TIMEOUT_MS));
  86. TEST_ASSERT((bits & ETH_PING_END_BIT) == ETH_PING_END_BIT);
  87. /* restart ping */
  88. TEST_ESP_OK(esp_ping_start(ping));
  89. vTaskDelay(pdMS_TO_TICKS(ETH_PING_DURATION_MS));
  90. TEST_ESP_OK(esp_ping_stop(ping));
  91. bits = xEventGroupWaitBits(eth_event_group, ETH_PING_END_BIT, true, true, pdMS_TO_TICKS(ETH_PING_END_TIMEOUT_MS));
  92. TEST_ASSERT((bits & ETH_PING_END_BIT) == ETH_PING_END_BIT);
  93. /* de-initialize ping process */
  94. TEST_ESP_OK(esp_ping_delete_session(ping));
  95. vEventGroupDelete(eth_event_group);
  96. }