mirror of
https://github.com/zeromq/libzmq.git
synced 2025-01-31 14:39:55 +01:00
Problem: test_stream not yet using unity
Solution: migrate to unity
This commit is contained in:
parent
7ad0ff5e9a
commit
2334090732
@ -544,7 +544,8 @@ tests_test_probe_router_LDADD = src/libzmq.la ${UNITY_LIBS}
|
|||||||
tests_test_probe_router_CPPFLAGS = ${UNITY_CPPFLAGS}
|
tests_test_probe_router_CPPFLAGS = ${UNITY_CPPFLAGS}
|
||||||
|
|
||||||
tests_test_stream_SOURCES = tests/test_stream.cpp
|
tests_test_stream_SOURCES = tests/test_stream.cpp
|
||||||
tests_test_stream_LDADD = src/libzmq.la
|
tests_test_stream_LDADD = src/libzmq.la ${UNITY_LIBS}
|
||||||
|
tests_test_stream_CPPFLAGS = ${UNITY_CPPFLAGS}
|
||||||
|
|
||||||
tests_test_stream_empty_SOURCES = tests/test_stream_empty.cpp
|
tests_test_stream_empty_SOURCES = tests/test_stream_empty.cpp
|
||||||
tests_test_stream_empty_LDADD = src/libzmq.la ${UNITY_LIBS}
|
tests_test_stream_empty_LDADD = src/libzmq.la ${UNITY_LIBS}
|
||||||
|
@ -28,10 +28,21 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "testutil.hpp"
|
#include "testutil.hpp"
|
||||||
|
#include "testutil_unity.hpp"
|
||||||
|
|
||||||
|
void setUp ()
|
||||||
|
{
|
||||||
|
setup_test_context ();
|
||||||
|
}
|
||||||
|
|
||||||
|
void tearDown ()
|
||||||
|
{
|
||||||
|
teardown_test_context ();
|
||||||
|
}
|
||||||
|
|
||||||
// ZMTP protocol greeting structure
|
// ZMTP protocol greeting structure
|
||||||
|
|
||||||
typedef unsigned char byte;
|
typedef uint8_t byte;
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
byte signature[10]; // 0xFF 8*0x00 0x7F
|
byte signature[10]; // 0xFF 8*0x00 0x7F
|
||||||
@ -49,113 +60,97 @@ typedef struct
|
|||||||
static zmtp_greeting_t greeting = {
|
static zmtp_greeting_t greeting = {
|
||||||
{0xFF, 0, 0, 0, 0, 0, 0, 0, 1, 0x7F}, {3, 0}, {'N', 'U', 'L', 'L'}, 0, {0}};
|
{0xFF, 0, 0, 0, 0, 0, 0, 0, 1, 0x7F}, {3, 0}, {'N', 'U', 'L', 'L'}, 0, {0}};
|
||||||
|
|
||||||
static void test_stream_to_dealer (void)
|
static void test_stream_to_dealer ()
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
size_t len = MAX_SOCKET_STRING;
|
|
||||||
char my_endpoint[MAX_SOCKET_STRING];
|
char my_endpoint[MAX_SOCKET_STRING];
|
||||||
|
|
||||||
// Set up our context and sockets
|
|
||||||
void *ctx = zmq_ctx_new ();
|
|
||||||
assert (ctx);
|
|
||||||
|
|
||||||
// We'll be using this socket in raw mode
|
// We'll be using this socket in raw mode
|
||||||
void *stream = zmq_socket (ctx, ZMQ_STREAM);
|
void *stream = test_context_socket (ZMQ_STREAM);
|
||||||
assert (stream);
|
|
||||||
|
|
||||||
int zero = 0;
|
int zero = 0;
|
||||||
rc = zmq_setsockopt (stream, ZMQ_LINGER, &zero, sizeof (zero));
|
TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
assert (rc == 0);
|
zmq_setsockopt (stream, ZMQ_LINGER, &zero, sizeof (zero)));
|
||||||
int enabled = 1;
|
int enabled = 1;
|
||||||
rc = zmq_setsockopt (stream, ZMQ_STREAM_NOTIFY, &enabled, sizeof (enabled));
|
TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
assert (rc == 0);
|
zmq_setsockopt (stream, ZMQ_STREAM_NOTIFY, &enabled, sizeof (enabled)));
|
||||||
rc = zmq_bind (stream, "tcp://127.0.0.1:*");
|
bind_loopback_ipv4 (stream, my_endpoint, sizeof my_endpoint);
|
||||||
assert (rc == 0);
|
|
||||||
rc = zmq_getsockopt (stream, ZMQ_LAST_ENDPOINT, my_endpoint, &len);
|
|
||||||
assert (rc == 0);
|
|
||||||
|
|
||||||
|
|
||||||
// We'll be using this socket as the other peer
|
// We'll be using this socket as the other peer
|
||||||
void *dealer = zmq_socket (ctx, ZMQ_DEALER);
|
void *dealer = test_context_socket (ZMQ_DEALER);
|
||||||
assert (dealer);
|
TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
rc = zmq_setsockopt (dealer, ZMQ_LINGER, &zero, sizeof (zero));
|
zmq_setsockopt (dealer, ZMQ_LINGER, &zero, sizeof (zero)));
|
||||||
assert (rc == 0);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (dealer, my_endpoint));
|
||||||
rc = zmq_connect (dealer, my_endpoint);
|
|
||||||
|
|
||||||
// Send a message on the dealer socket
|
// Send a message on the dealer socket
|
||||||
rc = zmq_send (dealer, "Hello", 5, 0);
|
send_string_expect_success (dealer, "Hello", 0);
|
||||||
assert (rc == 5);
|
|
||||||
|
|
||||||
// Connecting sends a zero message
|
// Connecting sends a zero message
|
||||||
// First frame is routing id
|
// First frame is routing id
|
||||||
zmq_msg_t routing_id;
|
zmq_msg_t routing_id;
|
||||||
rc = zmq_msg_init (&routing_id);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_init (&routing_id));
|
||||||
assert (rc == 0);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_recv (&routing_id, stream, 0));
|
||||||
rc = zmq_msg_recv (&routing_id, stream, 0);
|
TEST_ASSERT_TRUE (zmq_msg_more (&routing_id));
|
||||||
assert (rc > 0);
|
|
||||||
assert (zmq_msg_more (&routing_id));
|
|
||||||
|
|
||||||
// Verify the existence of Peer-Address metadata
|
// Verify the existence of Peer-Address metadata
|
||||||
char const *peer_address = zmq_msg_gets (&routing_id, "Peer-Address");
|
char const *peer_address = zmq_msg_gets (&routing_id, "Peer-Address");
|
||||||
assert (peer_address != 0);
|
TEST_ASSERT_NOT_NULL (peer_address);
|
||||||
assert (streq (peer_address, "127.0.0.1"));
|
TEST_ASSERT_EQUAL_STRING ("127.0.0.1", peer_address);
|
||||||
|
|
||||||
// Second frame is zero
|
// Second frame is zero
|
||||||
byte buffer[255];
|
byte buffer[255];
|
||||||
rc = zmq_recv (stream, buffer, 255, 0);
|
TEST_ASSERT_EQUAL_INT (
|
||||||
assert (rc == 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (stream, buffer, 255, 0)));
|
||||||
|
|
||||||
// Verify the existence of Peer-Address metadata
|
// Verify the existence of Peer-Address metadata
|
||||||
peer_address = zmq_msg_gets (&routing_id, "Peer-Address");
|
peer_address = zmq_msg_gets (&routing_id, "Peer-Address");
|
||||||
assert (peer_address != 0);
|
TEST_ASSERT_NOT_NULL (peer_address);
|
||||||
assert (streq (peer_address, "127.0.0.1"));
|
TEST_ASSERT_EQUAL_STRING ("127.0.0.1", peer_address);
|
||||||
|
|
||||||
// Real data follows
|
// Real data follows
|
||||||
// First frame is routing id
|
// First frame is routing id
|
||||||
rc = zmq_msg_recv (&routing_id, stream, 0);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_recv (&routing_id, stream, 0));
|
||||||
assert (rc > 0);
|
TEST_ASSERT_TRUE (zmq_msg_more (&routing_id));
|
||||||
assert (zmq_msg_more (&routing_id));
|
|
||||||
|
|
||||||
// Verify the existence of Peer-Address metadata
|
// Verify the existence of Peer-Address metadata
|
||||||
peer_address = zmq_msg_gets (&routing_id, "Peer-Address");
|
peer_address = zmq_msg_gets (&routing_id, "Peer-Address");
|
||||||
assert (peer_address != 0);
|
TEST_ASSERT_NOT_NULL (peer_address);
|
||||||
assert (streq (peer_address, "127.0.0.1"));
|
TEST_ASSERT_EQUAL_STRING ("127.0.0.1", peer_address);
|
||||||
|
|
||||||
// Second frame is greeting signature
|
// Second frame is greeting signature
|
||||||
rc = zmq_recv (stream, buffer, 255, 0);
|
recv_array_expect_success (stream, greeting.signature, 0);
|
||||||
assert (rc == 10);
|
|
||||||
assert (memcmp (buffer, greeting.signature, 10) == 0);
|
|
||||||
|
|
||||||
// Send our own protocol greeting
|
// Send our own protocol greeting
|
||||||
rc = zmq_msg_send (&routing_id, stream, ZMQ_SNDMORE);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_send (&routing_id, stream, ZMQ_SNDMORE));
|
||||||
assert (rc > 0);
|
TEST_ASSERT_EQUAL_INT (
|
||||||
rc = zmq_send (stream, &greeting, sizeof (greeting), 0);
|
sizeof (greeting), TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
assert (rc == sizeof (greeting));
|
zmq_send (stream, &greeting, sizeof (greeting), 0)));
|
||||||
|
|
||||||
// Now we expect the data from the DEALER socket
|
// Now we expect the data from the DEALER socket
|
||||||
// We want the rest of greeting along with the Ready command
|
// We want the rest of greeting along with the Ready command
|
||||||
int bytes_read = 0;
|
int bytes_read = 0;
|
||||||
while (bytes_read < 97) {
|
while (bytes_read < 97) {
|
||||||
// First frame is the routing id of the connection (each time)
|
// First frame is the routing id of the connection (each time)
|
||||||
rc = zmq_msg_recv (&routing_id, stream, 0);
|
TEST_ASSERT_GREATER_THAN_INT (
|
||||||
assert (rc > 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_recv (&routing_id, stream, 0)));
|
||||||
assert (zmq_msg_more (&routing_id));
|
TEST_ASSERT_TRUE (zmq_msg_more (&routing_id));
|
||||||
// Second frame contains the next chunk of data
|
// Second frame contains the next chunk of data
|
||||||
rc = zmq_recv (stream, buffer + bytes_read, 255 - bytes_read, 0);
|
TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
assert (rc >= 0);
|
rc = zmq_recv (stream, buffer + bytes_read, 255 - bytes_read, 0));
|
||||||
bytes_read += rc;
|
bytes_read += rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
// First two bytes are major and minor version numbers.
|
// First two bytes are major and minor version numbers.
|
||||||
assert (buffer[0] == 3); // ZMTP/3.0
|
TEST_ASSERT_EQUAL_INT (3, buffer[0]); // ZMTP/3.0
|
||||||
assert (buffer[1] == 0);
|
TEST_ASSERT_EQUAL_INT (0, buffer[1]);
|
||||||
|
|
||||||
// Mechanism is "NULL"
|
// Mechanism is "NULL"
|
||||||
assert (memcmp (buffer + 2, "NULL\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 20)
|
TEST_ASSERT_EQUAL_INT8_ARRAY (buffer + 2,
|
||||||
== 0);
|
"NULL\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 20);
|
||||||
assert (memcmp (buffer + 54, "\4\51\5READY", 8) == 0);
|
TEST_ASSERT_EQUAL_INT8_ARRAY (buffer + 54, "\4\51\5READY", 8);
|
||||||
assert (memcmp (buffer + 62, "\13Socket-Type\0\0\0\6DEALER", 22) == 0);
|
TEST_ASSERT_EQUAL_INT8_ARRAY (buffer + 62, "\13Socket-Type\0\0\0\6DEALER",
|
||||||
assert (memcmp (buffer + 84, "\10Identity\0\0\0\0", 13) == 0);
|
22);
|
||||||
|
TEST_ASSERT_EQUAL_INT8_ARRAY (buffer + 84, "\10Identity\0\0\0\0", 13);
|
||||||
|
|
||||||
// Announce we are ready
|
// Announce we are ready
|
||||||
memcpy (buffer, "\4\51\5READY", 8);
|
memcpy (buffer, "\4\51\5READY", 8);
|
||||||
@ -163,37 +158,36 @@ static void test_stream_to_dealer (void)
|
|||||||
memcpy (buffer + 30, "\10Identity\0\0\0\0", 13);
|
memcpy (buffer + 30, "\10Identity\0\0\0\0", 13);
|
||||||
|
|
||||||
// Send Ready command
|
// Send Ready command
|
||||||
rc = zmq_msg_send (&routing_id, stream, ZMQ_SNDMORE);
|
TEST_ASSERT_GREATER_THAN_INT (0, TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_send (
|
||||||
assert (rc > 0);
|
&routing_id, stream, ZMQ_SNDMORE)));
|
||||||
rc = zmq_send (stream, buffer, 43, 0);
|
TEST_ASSERT_EQUAL_INT (
|
||||||
assert (rc == 43);
|
43, TEST_ASSERT_SUCCESS_ERRNO (zmq_send (stream, buffer, 43, 0)));
|
||||||
|
|
||||||
// Now we expect the data from the DEALER socket
|
// Now we expect the data from the DEALER socket
|
||||||
// First frame is, again, the routing id of the connection
|
// First frame is, again, the routing id of the connection
|
||||||
rc = zmq_msg_recv (&routing_id, stream, 0);
|
TEST_ASSERT_GREATER_THAN_INT (
|
||||||
assert (rc > 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_recv (&routing_id, stream, 0)));
|
||||||
assert (zmq_msg_more (&routing_id));
|
TEST_ASSERT_TRUE (zmq_msg_more (&routing_id));
|
||||||
|
|
||||||
// Third frame contains Hello message from DEALER
|
// Third frame contains Hello message from DEALER
|
||||||
rc = zmq_recv (stream, buffer, sizeof buffer, 0);
|
TEST_ASSERT_EQUAL_INT (7, TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
assert (rc == 7);
|
zmq_recv (stream, buffer, sizeof buffer, 0)));
|
||||||
|
|
||||||
// Then we have a 5-byte message "Hello"
|
// Then we have a 5-byte message "Hello"
|
||||||
assert (buffer[0] == 0); // Flags = 0
|
TEST_ASSERT_EQUAL_INT (0, buffer[0]); // Flags = 0
|
||||||
assert (buffer[1] == 5); // Size = 5
|
TEST_ASSERT_EQUAL_INT (5, buffer[1]); // Size = 5
|
||||||
assert (memcmp (buffer + 2, "Hello", 5) == 0);
|
TEST_ASSERT_EQUAL_INT8_ARRAY (buffer + 2, "Hello", 5);
|
||||||
|
|
||||||
// Send "World" back to DEALER
|
// Send "World" back to DEALER
|
||||||
rc = zmq_msg_send (&routing_id, stream, ZMQ_SNDMORE);
|
TEST_ASSERT_GREATER_THAN_INT (0, TEST_ASSERT_SUCCESS_ERRNO (zmq_msg_send (
|
||||||
assert (rc > 0);
|
&routing_id, stream, ZMQ_SNDMORE)));
|
||||||
byte world[] = {0, 5, 'W', 'o', 'r', 'l', 'd'};
|
byte world[] = {0, 5, 'W', 'o', 'r', 'l', 'd'};
|
||||||
rc = zmq_send (stream, world, sizeof (world), 0);
|
TEST_ASSERT_EQUAL_INT (
|
||||||
assert (rc == sizeof (world));
|
sizeof (world),
|
||||||
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_send (stream, world, sizeof (world), 0)));
|
||||||
|
|
||||||
// Expect response on DEALER socket
|
// Expect response on DEALER socket
|
||||||
rc = zmq_recv (dealer, buffer, 255, 0);
|
recv_string_expect_success (dealer, "World", 0);
|
||||||
assert (rc == 5);
|
|
||||||
assert (memcmp (buffer, "World", 5) == 0);
|
|
||||||
|
|
||||||
// Test large messages over STREAM socket
|
// Test large messages over STREAM socket
|
||||||
#define size 64000
|
#define size 64000
|
||||||
@ -206,110 +200,92 @@ static void test_stream_to_dealer (void)
|
|||||||
bytes_read = 0;
|
bytes_read = 0;
|
||||||
while (bytes_read < 9 + size) {
|
while (bytes_read < 9 + size) {
|
||||||
// Get routing id frame
|
// Get routing id frame
|
||||||
rc = zmq_recv (stream, buffer, 256, 0);
|
TEST_ASSERT_GREATER_THAN_INT (
|
||||||
assert (rc > 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (stream, buffer, 256, 0)));
|
||||||
// Get next chunk
|
// Get next chunk
|
||||||
rc = zmq_recv (stream, msgin + bytes_read, 9 + size - bytes_read, 0);
|
TEST_ASSERT_GREATER_THAN_INT (
|
||||||
assert (rc > 0);
|
0,
|
||||||
|
TEST_ASSERT_SUCCESS_ERRNO (rc = zmq_recv (stream, msgin + bytes_read,
|
||||||
|
9 + size - bytes_read, 0)));
|
||||||
bytes_read += rc;
|
bytes_read += rc;
|
||||||
}
|
}
|
||||||
int byte_nbr;
|
for (int byte_nbr = 0; byte_nbr < size; byte_nbr++) {
|
||||||
for (byte_nbr = 0; byte_nbr < size; byte_nbr++) {
|
TEST_ASSERT_EQUAL_UINT8 (0xAB, msgin[9 + byte_nbr]);
|
||||||
if (msgin[9 + byte_nbr] != 0xAB)
|
|
||||||
assert (false);
|
|
||||||
}
|
}
|
||||||
rc = zmq_close (dealer);
|
test_context_socket_close (dealer);
|
||||||
assert (rc == 0);
|
test_context_socket_close (stream);
|
||||||
|
|
||||||
rc = zmq_close (stream);
|
|
||||||
assert (rc == 0);
|
|
||||||
|
|
||||||
rc = zmq_ctx_term (ctx);
|
|
||||||
assert (rc == 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void test_stream_to_stream (void)
|
static void test_stream_to_stream ()
|
||||||
{
|
{
|
||||||
int rc;
|
|
||||||
size_t len = MAX_SOCKET_STRING;
|
|
||||||
char my_endpoint[MAX_SOCKET_STRING];
|
char my_endpoint[MAX_SOCKET_STRING];
|
||||||
// Set-up our context and sockets
|
// Set-up our context and sockets
|
||||||
void *ctx = zmq_ctx_new ();
|
|
||||||
assert (ctx);
|
|
||||||
|
|
||||||
void *server = zmq_socket (ctx, ZMQ_STREAM);
|
void *server = test_context_socket (ZMQ_STREAM);
|
||||||
assert (server);
|
|
||||||
int enabled = 1;
|
int enabled = 1;
|
||||||
rc = zmq_setsockopt (server, ZMQ_STREAM_NOTIFY, &enabled, sizeof (enabled));
|
TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
assert (rc == 0);
|
zmq_setsockopt (server, ZMQ_STREAM_NOTIFY, &enabled, sizeof (enabled)));
|
||||||
rc = zmq_bind (server, "tcp://127.0.0.1:*");
|
bind_loopback_ipv4 (server, my_endpoint, sizeof my_endpoint);
|
||||||
assert (rc == 0);
|
|
||||||
rc = zmq_getsockopt (server, ZMQ_LAST_ENDPOINT, my_endpoint, &len);
|
|
||||||
assert (rc == 0);
|
|
||||||
|
|
||||||
void *client = zmq_socket (ctx, ZMQ_STREAM);
|
void *client = test_context_socket (ZMQ_STREAM);
|
||||||
assert (client);
|
TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
rc = zmq_setsockopt (client, ZMQ_STREAM_NOTIFY, &enabled, sizeof (enabled));
|
zmq_setsockopt (client, ZMQ_STREAM_NOTIFY, &enabled, sizeof (enabled)));
|
||||||
assert (rc == 0);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (client, my_endpoint));
|
||||||
rc = zmq_connect (client, my_endpoint);
|
|
||||||
assert (rc == 0);
|
|
||||||
uint8_t id[256];
|
uint8_t id[256];
|
||||||
size_t id_size = 256;
|
|
||||||
uint8_t buffer[256];
|
uint8_t buffer[256];
|
||||||
|
|
||||||
// Connecting sends a zero message
|
// Connecting sends a zero message
|
||||||
// Server: First frame is routing id, second frame is zero
|
// Server: First frame is routing id, second frame is zero
|
||||||
id_size = zmq_recv (server, id, 256, 0);
|
TEST_ASSERT_GREATER_THAN_INT (
|
||||||
assert (id_size > 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (server, id, 256, 0)));
|
||||||
rc = zmq_recv (server, buffer, 256, 0);
|
TEST_ASSERT_EQUAL_INT (
|
||||||
assert (rc == 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (server, buffer, 256, 0)));
|
||||||
// Client: First frame is routing id, second frame is zero
|
// Client: First frame is routing id, second frame is zero
|
||||||
id_size = zmq_recv (client, id, 256, 0);
|
TEST_ASSERT_GREATER_THAN_INT (
|
||||||
assert (id_size > 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (client, id, 256, 0)));
|
||||||
rc = zmq_recv (client, buffer, 256, 0);
|
TEST_ASSERT_EQUAL_INT (
|
||||||
assert (rc == 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (client, buffer, 256, 0)));
|
||||||
|
|
||||||
// Sent HTTP request on client socket
|
// Sent HTTP request on client socket
|
||||||
// Get server routing id
|
// Get server routing id
|
||||||
rc = zmq_getsockopt (client, ZMQ_ROUTING_ID, id, &id_size);
|
size_t id_size = sizeof id;
|
||||||
assert (rc == 0);
|
TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
|
zmq_getsockopt (client, ZMQ_ROUTING_ID, id, &id_size));
|
||||||
// First frame is server routing id
|
// First frame is server routing id
|
||||||
rc = zmq_send (client, id, id_size, ZMQ_SNDMORE);
|
TEST_ASSERT_EQUAL_INT ((int) id_size, TEST_ASSERT_SUCCESS_ERRNO (zmq_send (
|
||||||
assert (rc == (int) id_size);
|
client, id, id_size, ZMQ_SNDMORE)));
|
||||||
// Second frame is HTTP GET request
|
// Second frame is HTTP GET request
|
||||||
rc = zmq_send (client, "GET /\n\n", 7, 0);
|
TEST_ASSERT_EQUAL_INT (
|
||||||
assert (rc == 7);
|
7, TEST_ASSERT_SUCCESS_ERRNO (zmq_send (client, "GET /\n\n", 7, 0)));
|
||||||
|
|
||||||
// Get HTTP request; ID frame and then request
|
// Get HTTP request; ID frame and then request
|
||||||
id_size = zmq_recv (server, id, 256, 0);
|
TEST_ASSERT_GREATER_THAN_INT (
|
||||||
assert (id_size > 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (server, id, 256, 0)));
|
||||||
rc = zmq_recv (server, buffer, 256, 0);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (server, buffer, 256, 0));
|
||||||
assert (rc != -1);
|
TEST_ASSERT_EQUAL_INT8_ARRAY (buffer, "GET /\n\n", 7);
|
||||||
assert (memcmp (buffer, "GET /\n\n", 7) == 0);
|
|
||||||
|
|
||||||
// Send reply back to client
|
// Send reply back to client
|
||||||
char http_response[] = "HTTP/1.0 200 OK\r\n"
|
char http_response[] = "HTTP/1.0 200 OK\r\n"
|
||||||
"Content-Type: text/plain\r\n"
|
"Content-Type: text/plain\r\n"
|
||||||
"\r\n"
|
"\r\n"
|
||||||
"Hello, World!";
|
"Hello, World!";
|
||||||
rc = zmq_send (server, id, id_size, ZMQ_SNDMORE);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_send (server, id, id_size, ZMQ_SNDMORE));
|
||||||
assert (rc != -1);
|
TEST_ASSERT_SUCCESS_ERRNO (
|
||||||
rc = zmq_send (server, http_response, sizeof (http_response), ZMQ_SNDMORE);
|
zmq_send (server, http_response, sizeof (http_response), ZMQ_SNDMORE));
|
||||||
assert (rc != -1);
|
|
||||||
|
|
||||||
// Send zero to close connection to client
|
// Send zero to close connection to client
|
||||||
rc = zmq_send (server, id, id_size, ZMQ_SNDMORE);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_send (server, id, id_size, ZMQ_SNDMORE));
|
||||||
assert (rc != -1);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_send (server, NULL, 0, ZMQ_SNDMORE));
|
||||||
rc = zmq_send (server, NULL, 0, ZMQ_SNDMORE);
|
|
||||||
assert (rc != -1);
|
|
||||||
|
|
||||||
// Get reply at client and check that it's complete
|
// Get reply at client and check that it's complete
|
||||||
id_size = zmq_recv (client, id, 256, 0);
|
TEST_ASSERT_GREATER_THAN_INT (
|
||||||
assert (id_size > 0);
|
0, TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (client, id, 256, 0)));
|
||||||
rc = zmq_recv (client, buffer, 256, 0);
|
TEST_ASSERT_EQUAL_INT (
|
||||||
assert (rc == sizeof (http_response));
|
sizeof http_response,
|
||||||
assert (memcmp (buffer, http_response, sizeof (http_response)) == 0);
|
TEST_ASSERT_SUCCESS_ERRNO (zmq_recv (client, buffer, 256, 0)));
|
||||||
|
TEST_ASSERT_EQUAL_INT8_ARRAY (buffer, http_response,
|
||||||
|
sizeof (http_response));
|
||||||
|
|
||||||
// // Get disconnection notification
|
// // Get disconnection notification
|
||||||
// FIXME: why does this block? Bug in STREAM disconnect notification?
|
// FIXME: why does this block? Bug in STREAM disconnect notification?
|
||||||
@ -318,19 +294,16 @@ static void test_stream_to_stream (void)
|
|||||||
// rc = zmq_recv (client, buffer, 256, 0);
|
// rc = zmq_recv (client, buffer, 256, 0);
|
||||||
// assert (rc == 0);
|
// assert (rc == 0);
|
||||||
|
|
||||||
rc = zmq_close (server);
|
test_context_socket_close (server);
|
||||||
assert (rc == 0);
|
test_context_socket_close (client);
|
||||||
|
|
||||||
rc = zmq_close (client);
|
|
||||||
assert (rc == 0);
|
|
||||||
|
|
||||||
rc = zmq_ctx_term (ctx);
|
|
||||||
assert (rc == 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int main (void)
|
int main ()
|
||||||
{
|
{
|
||||||
setup_test_environment ();
|
setup_test_environment ();
|
||||||
test_stream_to_dealer ();
|
|
||||||
test_stream_to_stream ();
|
UNITY_BEGIN ();
|
||||||
|
RUN_TEST (test_stream_to_dealer);
|
||||||
|
RUN_TEST (test_stream_to_stream);
|
||||||
|
return UNITY_END ();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user