1
0
mirror of https://github.com/VCMP-SqMod/SqMod.git synced 2025-06-24 19:17:12 +02:00
Files
.github
bin
module
vendor
CPR
CivetWeb
ConcurrentQueue
Fmt
MDBC
MaxmindDB
POCO
PUGIXML
SAJSON
SimpleIni
Squirrel
TinyDir
UTF8
ZMQ
RELICENSE
builds
doc
external
include
m4
packaging
perf
src
tests
CMakeLists.txt
README.md
test_abstract_ipc.cpp
test_address_tipc.cpp
test_ancillaries.cpp
test_app_meta.cpp
test_atomics.cpp
test_base85.cpp
test_bind_after_connect_tcp.cpp
test_bind_curve_fuzzer.cpp
test_bind_fuzzer.cpp
test_bind_null_fuzzer.cpp
test_bind_src_address.cpp
test_bind_stream_fuzzer.cpp
test_bind_ws_fuzzer.cpp
test_busy_poll.cpp
test_capabilities.cpp
test_channel.cpp
test_client_server.cpp
test_conflate.cpp
test_connect_curve_fuzzer.cpp
test_connect_delay_tipc.cpp
test_connect_fuzzer.cpp
test_connect_null_fuzzer.cpp
test_connect_resolve.cpp
test_connect_rid.cpp
test_connect_stream_fuzzer.cpp
test_connect_ws_fuzzer.cpp
test_ctx_destroy.cpp
test_ctx_options.cpp
test_dgram.cpp
test_diffserv.cpp
test_disconnect_inproc.cpp
test_disconnect_msg.cpp
test_filter_ipc.cpp
test_fork.cpp
test_getsockopt_memset.cpp
test_heartbeats.cpp
test_hello_msg.cpp
test_hiccup_msg.cpp
test_hwm.cpp
test_hwm_pubsub.cpp
test_immediate.cpp
test_inproc_connect.cpp
test_invalid_rep.cpp
test_iov.cpp
test_ipc_wildcard.cpp
test_issue_566.cpp
test_last_endpoint.cpp
test_many_sockets.cpp
test_metadata.cpp
test_mock_pub_sub.cpp
test_monitor.cpp
test_msg_ffn.cpp
test_msg_flags.cpp
test_msg_init.cpp
test_pair_inproc.cpp
test_pair_ipc.cpp
test_pair_tcp.cpp
test_pair_tcp_cap_net_admin.cpp
test_pair_tipc.cpp
test_pair_vmci.cpp
test_peer.cpp
test_poller.cpp
test_probe_router.cpp
test_proxy.cpp
test_proxy_hwm.cpp
test_proxy_single_socket.cpp
test_proxy_terminate.cpp
test_pub_invert_matching.cpp
test_pubsub.cpp
test_radio_dish.cpp
test_rebind_ipc.cpp
test_reconnect_ivl.cpp
test_reconnect_options.cpp
test_req_correlate.cpp
test_req_relaxed.cpp
test_reqrep_device.cpp
test_reqrep_device_tipc.cpp
test_reqrep_inproc.cpp
test_reqrep_ipc.cpp
test_reqrep_tcp.cpp
test_reqrep_tipc.cpp
test_reqrep_vmci.cpp
test_router_handover.cpp
test_router_mandatory.cpp
test_router_mandatory_hwm.cpp
test_router_mandatory_tipc.cpp
test_router_notify.cpp
test_scatter_gather.cpp
test_security_curve.cpp
test_security_gssapi.cpp
test_security_no_zap_handler.cpp
test_security_null.cpp
test_security_plain.cpp
test_security_zap.cpp
test_setsockopt.cpp
test_shutdown_stress.cpp
test_shutdown_stress_tipc.cpp
test_socket_null.cpp
test_socket_options_fuzzer.cpp
test_sockopt_hwm.cpp
test_socks.cpp
test_sodium.cpp
test_spec_dealer.cpp
test_spec_pushpull.cpp
test_spec_rep.cpp
test_spec_req.cpp
test_spec_router.cpp
test_srcfd.cpp
test_stream.cpp
test_stream_disconnect.cpp
test_stream_empty.cpp
test_stream_exceeds_buffer.cpp
test_stream_timeout.cpp
test_sub_forward.cpp
test_sub_forward_tipc.cpp
test_system.cpp
test_tcp_accept_filter.cpp
test_term_endpoint.cpp
test_term_endpoint_tipc.cpp
test_thread_safe.cpp
test_timeo.cpp
test_timers.cpp
test_unbind_wildcard.cpp
test_use_fd.cpp
test_ws_transport.cpp
test_wss_transport.cpp
test_xpub_manual.cpp
test_xpub_manual_last_value.cpp
test_xpub_nodrop.cpp
test_xpub_verbose.cpp
test_xpub_welcome_msg.cpp
test_z85_decode_fuzzer.cpp
test_zmq_poll_fd.cpp
testutil.cpp
testutil.hpp
testutil_monitoring.cpp
testutil_monitoring.hpp
testutil_security.cpp
testutil_security.hpp
testutil_unity.cpp
testutil_unity.hpp
tools
unittests
AUTHORS
CMakeLists.txt
COPYING
COPYING.LESSER
Dockerfile
Doxygen.cfg
INSTALL
Jenkinsfile
Makefile.am
NEWS
README.cygwin.md
README.doxygen.md
README.md
SECURITY.md
SupportedPlatforms.md
acinclude.m4
appveyor.yml
autogen.sh
branding.bmp
ci_build.sh
ci_deploy.sh
config.sh
configure.ac
installer.ico
version.sh
xxHash
CMakeLists.txt
.gitignore
.gitmodules
CMakeLists.txt
LICENSE
README.md
SqMod/vendor/ZMQ/tests/test_spec_router.cpp
Sandu Liviu Catalin fc9419677f Initial ZMQ bindings.
2021-02-02 19:07:02 +02:00

192 lines
6.5 KiB
C++

/*
Copyright (c) 2007-2017 Contributors as noted in the AUTHORS file
This file is part of libzmq, the ZeroMQ core engine in C++.
libzmq is free software; you can redistribute it and/or modify it under
the terms of the GNU Lesser General Public License (LGPL) as published
by the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
As a special exception, the Contributors give you permission to link
this library with independent modules to produce an executable,
regardless of the license terms of these independent modules, and to
copy and distribute the resulting executable under terms of your choice,
provided that you also meet, for each linked independent module, the
terms and conditions of the license of that module. An independent
module is a module which is not derived from or based on this library.
If you modify this library, you must extend this exception to your
version of the library.
libzmq is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "testutil.hpp"
#include "testutil_unity.hpp"
#include <stdlib.h>
#include <string.h>
SETUP_TEARDOWN_TESTCONTEXT
// SHALL receive incoming messages from its peers using a fair-queuing
// strategy.
void test_fair_queue_in (const char *bind_address_)
{
char connect_address[MAX_SOCKET_STRING];
void *receiver = test_context_socket (ZMQ_ROUTER);
TEST_ASSERT_SUCCESS_ERRNO (zmq_bind (receiver, bind_address_));
size_t len = MAX_SOCKET_STRING;
TEST_ASSERT_SUCCESS_ERRNO (
zmq_getsockopt (receiver, ZMQ_LAST_ENDPOINT, connect_address, &len));
const unsigned char services = 5;
void *senders[services];
for (unsigned char peer = 0; peer < services; ++peer) {
senders[peer] = test_context_socket (ZMQ_DEALER);
char *str = strdup ("A");
str[0] += peer;
TEST_ASSERT_SUCCESS_ERRNO (
zmq_setsockopt (senders[peer], ZMQ_ROUTING_ID, str, 2));
free (str);
TEST_ASSERT_SUCCESS_ERRNO (
zmq_connect (senders[peer], connect_address));
}
msleep (SETTLE_TIME);
zmq_msg_t msg;
TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_init (&msg));
s_send_seq (senders[0], "M", SEQ_END);
s_recv_seq (receiver, "A", "M", SEQ_END);
s_send_seq (senders[0], "M", SEQ_END);
s_recv_seq (receiver, "A", "M", SEQ_END);
int sum = 0;
// send N requests
for (unsigned char peer = 0; peer < services; ++peer) {
s_send_seq (senders[peer], "M", SEQ_END);
sum += 'A' + peer;
}
TEST_ASSERT_EQUAL_INT (services * 'A' + services * (services - 1) / 2, sum);
// handle N requests
for (unsigned char peer = 0; peer < services; ++peer) {
TEST_ASSERT_EQUAL_INT (
2, TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_recv (&msg, receiver, 0)));
const char *id = static_cast<const char *> (zmq_msg_data (&msg));
sum -= id[0];
s_recv_seq (receiver, "M", SEQ_END);
}
TEST_ASSERT_EQUAL_INT (0, sum);
TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_close (&msg));
test_context_socket_close_zero_linger (receiver);
for (size_t peer = 0; peer < services; ++peer)
test_context_socket_close_zero_linger (senders[peer]);
// Wait for disconnects.
msleep (SETTLE_TIME);
}
// SHALL create a double queue when a peer connects to it. If this peer
// disconnects, the ROUTER socket SHALL destroy its double queue and SHALL
// discard any messages it contains.
void test_destroy_queue_on_disconnect (const char *bind_address_)
{
void *a = test_context_socket (ZMQ_ROUTER);
int enabled = 1;
TEST_ASSERT_SUCCESS_ERRNO (
zmq_setsockopt (a, ZMQ_ROUTER_MANDATORY, &enabled, sizeof (enabled)));
TEST_ASSERT_SUCCESS_ERRNO (zmq_bind (a, bind_address_));
size_t len = MAX_SOCKET_STRING;
char connect_address[MAX_SOCKET_STRING];
TEST_ASSERT_SUCCESS_ERRNO (
zmq_getsockopt (a, ZMQ_LAST_ENDPOINT, connect_address, &len));
void *b = test_context_socket (ZMQ_DEALER);
TEST_ASSERT_SUCCESS_ERRNO (zmq_setsockopt (b, ZMQ_ROUTING_ID, "B", 2));
TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (b, connect_address));
// Wait for connection.
msleep (SETTLE_TIME);
// Send a message in both directions
s_send_seq (a, "B", "ABC", SEQ_END);
s_send_seq (b, "DEF", SEQ_END);
TEST_ASSERT_SUCCESS_ERRNO (zmq_disconnect (b, connect_address));
// Disconnect may take time and need command processing.
zmq_pollitem_t poller[2] = {{a, 0, 0, 0}, {b, 0, 0, 0}};
TEST_ASSERT_SUCCESS_ERRNO (zmq_poll (poller, 2, 100));
TEST_ASSERT_SUCCESS_ERRNO (zmq_poll (poller, 2, 100));
// No messages should be available, sending should fail.
zmq_msg_t msg;
zmq_msg_init (&msg);
TEST_ASSERT_FAILURE_ERRNO (
EHOSTUNREACH, zmq_send (a, "B", 2, ZMQ_SNDMORE | ZMQ_DONTWAIT));
TEST_ASSERT_FAILURE_ERRNO (EAGAIN, zmq_msg_recv (&msg, a, ZMQ_DONTWAIT));
// After a reconnect of B, the messages should still be gone
TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (b, connect_address));
TEST_ASSERT_FAILURE_ERRNO (EAGAIN, zmq_msg_recv (&msg, a, ZMQ_DONTWAIT));
TEST_ASSERT_FAILURE_ERRNO (EAGAIN, zmq_msg_recv (&msg, b, ZMQ_DONTWAIT));
TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_close (&msg));
test_context_socket_close_zero_linger (a);
test_context_socket_close_zero_linger (b);
// Wait for disconnects.
msleep (SETTLE_TIME);
}
#define TEST_SUITE(name, bind_address) \
void test_fair_queue_in_##name () { test_fair_queue_in (bind_address); } \
void test_destroy_queue_on_disconnect_##name () \
{ \
test_destroy_queue_on_disconnect (bind_address); \
}
TEST_SUITE (inproc, "inproc://a")
TEST_SUITE (tcp, "tcp://127.0.0.1:*")
int main ()
{
setup_test_environment ();
UNITY_BEGIN ();
RUN_TEST (test_fair_queue_in_tcp);
RUN_TEST (test_fair_queue_in_inproc);
// TODO commented out until libzmq implements this properly
// RUN_TEST (test_destroy_queue_on_disconnect_tcp);
// RUN_TEST (test_destroy_queue_on_disconnect_inproc);
return UNITY_END ();
}