0
0
mirror of https://github.com/zeromq/libzmq.git synced 2025-01-15 02:07:59 +08:00

Merge pull request #3456 from bluca/test_fd_port

Problem: TCP and UDP test sockets use hard-coded port
This commit is contained in:
Simon Giesecke 2019-03-19 17:57:09 +01:00 committed by GitHub
commit 99e53698c5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 34 additions and 43 deletions

1
.gitignore vendored
View File

@ -74,6 +74,7 @@ test_ctx_options
test_iov test_iov
test_security test_security
test_security_curve test_security_curve
test_security_no_zap_handler
test_probe_router test_probe_router
test_stream test_stream
test_spec_dealer test_spec_dealer

View File

@ -40,13 +40,6 @@ void tearDown ()
teardown_test_context (); teardown_test_context ();
} }
#if defined(ZMQ_HAVE_WINDOWS)
#include <winsock2.h>
#include <ws2tcpip.h>
#include <stdexcept>
#define close closesocket
#endif
void test_stream_exceeds_buffer () void test_stream_exceeds_buffer ()
{ {
const int msgsize = 8193; const int msgsize = 8193;
@ -60,26 +53,9 @@ void test_stream_exceeds_buffer ()
TEST_ASSERT_SUCCESS_RAW_ERRNO (setsockopt (server_sock, SOL_SOCKET, TEST_ASSERT_SUCCESS_RAW_ERRNO (setsockopt (server_sock, SOL_SOCKET,
SO_REUSEADDR, (char *) &enable, SO_REUSEADDR, (char *) &enable,
sizeof (enable))); sizeof (enable)));
struct sockaddr_in saddr = bind_bsd_socket (server_sock);
struct sockaddr_in saddr;
memset (&saddr, 0, sizeof (saddr));
saddr.sin_family = AF_INET;
saddr.sin_addr.s_addr = INADDR_ANY;
#if !defined(_WIN32_WINNT) || (_WIN32_WINNT >= 0x0600)
saddr.sin_port = 0;
#else
saddr.sin_port = htons (12345);
#endif
TEST_ASSERT_SUCCESS_RAW_ERRNO (
bind (server_sock, (struct sockaddr *) &saddr, sizeof (saddr)));
TEST_ASSERT_SUCCESS_RAW_ERRNO (listen (server_sock, 1)); TEST_ASSERT_SUCCESS_RAW_ERRNO (listen (server_sock, 1));
#if !defined(_WIN32_WINNT) || (_WIN32_WINNT >= 0x0600)
socklen_t saddr_len = sizeof (saddr);
TEST_ASSERT_SUCCESS_RAW_ERRNO (
getsockname (server_sock, (struct sockaddr *) &saddr, &saddr_len));
#endif
sprintf (my_endpoint, "tcp://127.0.0.1:%d", ntohs (saddr.sin_port)); sprintf (my_endpoint, "tcp://127.0.0.1:%d", ntohs (saddr.sin_port));
void *zsock = test_context_socket (ZMQ_STREAM); void *zsock = test_context_socket (ZMQ_STREAM);

View File

@ -45,18 +45,6 @@ void tearDown ()
void test_poll_fd () void test_poll_fd ()
{ {
struct addrinfo *addr, hint;
hint.ai_flags = AI_NUMERICHOST;
hint.ai_family = AF_INET;
hint.ai_socktype = SOCK_DGRAM;
hint.ai_protocol = IPPROTO_UDP;
hint.ai_addrlen = 0;
hint.ai_canonname = NULL;
hint.ai_addr = NULL;
hint.ai_next = NULL;
TEST_ASSERT_SUCCESS_ERRNO (getaddrinfo ("127.0.0.1", "6650", &hint, &addr));
int recv_socket = socket (AF_INET, SOCK_DGRAM, IPPROTO_UDP); int recv_socket = socket (AF_INET, SOCK_DGRAM, IPPROTO_UDP);
TEST_ASSERT_NOT_EQUAL (-1, recv_socket); TEST_ASSERT_NOT_EQUAL (-1, recv_socket);
@ -64,8 +52,7 @@ void test_poll_fd ()
TEST_ASSERT_SUCCESS_ERRNO ( TEST_ASSERT_SUCCESS_ERRNO (
setsockopt (recv_socket, SOL_SOCKET, SO_REUSEADDR, &flag, sizeof (int))); setsockopt (recv_socket, SOL_SOCKET, SO_REUSEADDR, &flag, sizeof (int)));
TEST_ASSERT_SUCCESS_ERRNO ( struct sockaddr_in saddr = bind_bsd_socket (recv_socket);
bind (recv_socket, addr->ai_addr, addr->ai_addrlen));
void *sb = test_context_socket (ZMQ_REP); void *sb = test_context_socket (ZMQ_REP);
@ -82,8 +69,8 @@ void test_poll_fd ()
char buf[10]; char buf[10];
memset (buf, 1, 10); memset (buf, 1, 10);
TEST_ASSERT_SUCCESS_ERRNO ( TEST_ASSERT_SUCCESS_ERRNO (sendto (
sendto (send_socket, buf, 10, 0, addr->ai_addr, addr->ai_addrlen)); send_socket, buf, 10, 0, (struct sockaddr *) &saddr, sizeof (saddr)));
TEST_ASSERT_EQUAL (1, zmq_poll (pollitems, 2, 1)); TEST_ASSERT_EQUAL (1, zmq_poll (pollitems, 2, 1));
TEST_ASSERT_BITS_LOW (ZMQ_POLLIN, pollitems[0].revents); TEST_ASSERT_BITS_LOW (ZMQ_POLLIN, pollitems[0].revents);
@ -93,8 +80,6 @@ void test_poll_fd ()
close (send_socket); close (send_socket);
close (recv_socket); close (recv_socket);
freeaddrinfo (addr);
} }
int main () int main ()

View File

@ -55,6 +55,7 @@
#define ENDPOINT_3 "tcp://127.0.0.1:5558" #define ENDPOINT_3 "tcp://127.0.0.1:5558"
#define ENDPOINT_4 "udp://127.0.0.1:5559" #define ENDPOINT_4 "udp://127.0.0.1:5559"
#define ENDPOINT_5 "udp://127.0.0.1:5560" #define ENDPOINT_5 "udp://127.0.0.1:5560"
#define PORT_6 5561
#undef NDEBUG #undef NDEBUG
#include <time.h> #include <time.h>
@ -94,6 +95,9 @@
// duplicated from fd.hpp // duplicated from fd.hpp
#ifdef ZMQ_HAVE_WINDOWS #ifdef ZMQ_HAVE_WINDOWS
#include <winsock2.h>
#include <ws2tcpip.h>
#include <stdexcept>
#define close closesocket #define close closesocket
typedef int socket_size_t; typedef int socket_size_t;
const char *as_setsockopt_opt_t (const void *opt) const char *as_setsockopt_opt_t (const void *opt)
@ -474,4 +478,29 @@ int test_inet_pton (int af_, const char *src_, void *dst_)
#endif #endif
} }
// Binds an ipv4 BSD socket to an ephemeral port, returns the compiled sockaddr
struct sockaddr_in bind_bsd_socket (int socket)
{
struct sockaddr_in saddr;
memset (&saddr, 0, sizeof (saddr));
saddr.sin_family = AF_INET;
saddr.sin_addr.s_addr = INADDR_ANY;
#if !defined(_WIN32_WINNT) || (_WIN32_WINNT >= 0x0600)
saddr.sin_port = 0;
#else
saddr.sin_port = htons (PORT_6);
#endif
int rc = bind (socket, (struct sockaddr *) &saddr, sizeof (saddr));
assert (rc == 0);
#if !defined(_WIN32_WINNT) || (_WIN32_WINNT >= 0x0600)
socklen_t saddr_len = sizeof (saddr);
rc = getsockname (socket, (struct sockaddr *) &saddr, &saddr_len);
assert (rc == 0);
#endif
return saddr;
}
#endif #endif