void test_shutdown_stress_tipc () { void *s1; void *s2; int i; int j; pthread_t threads[THREAD_COUNT]; for (j = 0; j != 10; j++) { // Check the shutdown with many parallel I/O threads. setup_test_context (); zmq_ctx_set (get_test_context (), ZMQ_IO_THREADS, 7); s1 = test_context_socket (ZMQ_PUB); TEST_ASSERT_SUCCESS_ERRNO (zmq_bind (s1, "tipc://{5560,0,0}")); for (i = 0; i != THREAD_COUNT; i++) { s2 = zmq_socket (get_test_context (), ZMQ_SUB); TEST_ASSERT_SUCCESS_RAW_ERRNO ( pthread_create (&threads[i], NULL, worker, s2)); } for (i = 0; i != THREAD_COUNT; i++) { TEST_ASSERT_SUCCESS_RAW_ERRNO (pthread_join (threads[i], NULL)); } test_context_socket_close (s1); teardown_test_context (); } }
void test_reconnect_ivl_tcp_ipv6 () { if (is_ipv6_available ()) { zmq_ctx_set (get_test_context (), ZMQ_IPV6, 1); test_reconnect_ivl_tcp ("tcp://[::1]:*"); } }
void test_reconnect_ivl_tcp_ipv6 () { if (is_ipv6_available ()) { zmq_ctx_set (get_test_context (), ZMQ_IPV6, 1); test_reconnect_ivl_tcp (bind_loopback_ipv6); } }
static void setup_zap_handler () { // Spawn ZAP handler // We create and bind ZAP socket in main thread to avoid case // where child thread does not start up fast enough. void *handler = zmq_socket (get_test_context (), ZMQ_REP); TEST_ASSERT_SUCCESS_ERRNO (zmq_bind (handler, "inproc://zeromq.zap.01")); zap_thread = zmq_threadstart (&zap_handler, handler); }
void test_shutdown_during_pend () { // Connect first void *connect_socket = test_context_socket (ZMQ_PAIR); TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (connect_socket, "inproc://cbb")); zmq_ctx_shutdown (get_test_context ()); // Cleanup test_context_socket_close (connect_socket); }
static void simult_bind (void *endpt_) { // Pull out arguments - context followed by endpoint string const char *endpt = static_cast<const char *> (endpt_); // Bind // do not use test_context_socket here, as it is not thread-safe void *bind_socket = zmq_socket (get_test_context (), ZMQ_PUB); TEST_ASSERT_SUCCESS_ERRNO (zmq_bind (bind_socket, endpt)); // Cleanup TEST_ASSERT_SUCCESS_ERRNO (zmq_close (bind_socket)); }
static void simult_conn (void *endpt_) { // Pull out arguments - endpoint string const char *endpt = static_cast<const char *> (endpt_); // Connect // do not use test_context_socket here, as it is not thread-safe void *connect_socket = zmq_socket (get_test_context (), ZMQ_SUB); TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (connect_socket, endpt)); // Cleanup TEST_ASSERT_SUCCESS_ERRNO (zmq_close (connect_socket)); }
static void pusher (void * /*unused*/) { // Connect first // do not use test_context_socket here, as it is not thread-safe void *connect_socket = zmq_socket (get_test_context (), ZMQ_PAIR); TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (connect_socket, "inproc://sink")); // Queue up some data send_string_expect_success (connect_socket, "foobar", 0); // Cleanup TEST_ASSERT_SUCCESS_ERRNO (zmq_close (connect_socket)); }
void test_metadata () { char my_endpoint[MAX_SOCKET_STRING]; setup_test_context (); // Spawn ZAP handler // We create and bind ZAP socket in main thread to avoid case // where child thread does not start up fast enough. void *handler = zmq_socket (get_test_context (), ZMQ_REP); TEST_ASSERT_NOT_NULL (handler); TEST_ASSERT_SUCCESS_ERRNO (zmq_bind (handler, "inproc://zeromq.zap.01")); void *zap_thread = zmq_threadstart (&zap_handler, handler); void *server = test_context_socket (ZMQ_DEALER); void *client = test_context_socket (ZMQ_DEALER); TEST_ASSERT_SUCCESS_ERRNO ( zmq_setsockopt (server, ZMQ_ZAP_DOMAIN, "DOMAIN", 6)); bind_loopback_ipv4 (server, my_endpoint, sizeof (my_endpoint)); TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (client, my_endpoint)); s_send (client, "This is a message"); zmq_msg_t msg; zmq_msg_init (&msg); TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_recv (&msg, server, 0)); TEST_ASSERT_EQUAL_STRING ("World", zmq_msg_gets (&msg, "Hello")); TEST_ASSERT_EQUAL_STRING ("DEALER", zmq_msg_gets (&msg, "Socket-Type")); TEST_ASSERT_EQUAL_STRING ("anonymous", zmq_msg_gets (&msg, "User-Id")); TEST_ASSERT_EQUAL_STRING ("127.0.0.1", zmq_msg_gets (&msg, "Peer-Address")); TEST_ASSERT_NULL (zmq_msg_gets (&msg, "No Such")); TEST_ASSERT_EQUAL_INT (EINVAL, zmq_errno ()); zmq_msg_close (&msg); test_context_socket_close_zero_linger (client); test_context_socket_close_zero_linger (server); // Shutdown teardown_test_context (); // Wait until ZAP handler terminates zmq_threadclose (zap_thread); }