test-udp-create-socket-early.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. /* Copyright (c) 2015 Saúl Ibarra Corretgé <saghul@gmail.com>.
  2. * All rights reserved.
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a copy
  5. * of this software and associated documentation files (the "Software"), to
  6. * deal in the Software without restriction, including without limitation the
  7. * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
  8. * sell copies of the Software, and to permit persons to whom the Software is
  9. * furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in
  12. * all copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  19. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  20. * IN THE SOFTWARE.
  21. */
  22. #include "uv.h"
  23. #include "task.h"
  24. #include <string.h>
  25. #ifdef _WIN32
  26. # define INVALID_FD (INVALID_HANDLE_VALUE)
  27. #else
  28. # define INVALID_FD (-1)
  29. #endif
  30. TEST_IMPL(udp_create_early) {
  31. struct sockaddr_in addr;
  32. struct sockaddr_in sockname;
  33. uv_udp_t client;
  34. uv_os_fd_t fd;
  35. int r, namelen;
  36. ASSERT(0 == uv_ip4_addr("127.0.0.1", TEST_PORT, &addr));
  37. r = uv_udp_init_ex(uv_default_loop(), &client, AF_INET);
  38. ASSERT(r == 0);
  39. r = uv_fileno((const uv_handle_t*) &client, &fd);
  40. ASSERT(r == 0);
  41. ASSERT(fd != INVALID_FD);
  42. /* Windows returns WSAEINVAL if the socket is not bound */
  43. #ifndef _WIN32
  44. namelen = sizeof sockname;
  45. r = uv_udp_getsockname(&client, (struct sockaddr*) &sockname, &namelen);
  46. ASSERT(r == 0);
  47. ASSERT(sockname.sin_family == AF_INET);
  48. #endif
  49. r = uv_udp_bind(&client, (const struct sockaddr*) &addr, 0);
  50. ASSERT(r == 0);
  51. namelen = sizeof sockname;
  52. r = uv_udp_getsockname(&client, (struct sockaddr*) &sockname, &namelen);
  53. ASSERT(r == 0);
  54. ASSERT(memcmp(&addr.sin_addr,
  55. &sockname.sin_addr,
  56. sizeof(addr.sin_addr)) == 0);
  57. uv_close((uv_handle_t*) &client, NULL);
  58. uv_run(uv_default_loop(), UV_RUN_DEFAULT);
  59. MAKE_VALGRIND_HAPPY();
  60. return 0;
  61. }
  62. TEST_IMPL(udp_create_early_bad_bind) {
  63. struct sockaddr_in addr;
  64. uv_udp_t client;
  65. uv_os_fd_t fd;
  66. int r;
  67. if (!can_ipv6())
  68. RETURN_SKIP("IPv6 not supported");
  69. ASSERT(0 == uv_ip4_addr("127.0.0.1", TEST_PORT, &addr));
  70. r = uv_udp_init_ex(uv_default_loop(), &client, AF_INET6);
  71. ASSERT(r == 0);
  72. r = uv_fileno((const uv_handle_t*) &client, &fd);
  73. ASSERT(r == 0);
  74. ASSERT(fd != INVALID_FD);
  75. /* Windows returns WSAEINVAL if the socket is not bound */
  76. #ifndef _WIN32
  77. {
  78. int namelen;
  79. struct sockaddr_in6 sockname;
  80. namelen = sizeof sockname;
  81. r = uv_udp_getsockname(&client, (struct sockaddr*) &sockname, &namelen);
  82. ASSERT(r == 0);
  83. ASSERT(sockname.sin6_family == AF_INET6);
  84. }
  85. #endif
  86. r = uv_udp_bind(&client, (const struct sockaddr*) &addr, 0);
  87. #if !defined(_WIN32) && !defined(__CYGWIN__) && !defined(__MSYS__)
  88. ASSERT(r == UV_EINVAL);
  89. #else
  90. ASSERT(r == UV_EFAULT);
  91. #endif
  92. uv_close((uv_handle_t*) &client, NULL);
  93. uv_run(uv_default_loop(), UV_RUN_DEFAULT);
  94. MAKE_VALGRIND_HAPPY();
  95. return 0;
  96. }
  97. TEST_IMPL(udp_create_early_bad_domain) {
  98. uv_udp_t client;
  99. int r;
  100. r = uv_udp_init_ex(uv_default_loop(), &client, 47);
  101. ASSERT(r == UV_EINVAL);
  102. r = uv_udp_init_ex(uv_default_loop(), &client, 1024);
  103. ASSERT(r == UV_EINVAL);
  104. uv_run(uv_default_loop(), UV_RUN_DEFAULT);
  105. MAKE_VALGRIND_HAPPY();
  106. return 0;
  107. }