diff options
| -rw-r--r-- | tests/Makefile.am | 4 | ||||
| -rw-r--r-- | tests/test_reconnect.cpp | 64 | 
2 files changed, 67 insertions, 1 deletions
| diff --git a/tests/Makefile.am b/tests/Makefile.am index 06830e2..a63c1de 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -11,7 +11,8 @@ noinst_PROGRAMS = test_pair_inproc \                    test_reqrep_device \                    test_sub_forward \                    test_invalid_rep \ -                  test_msg_flags +                  test_msg_flags \ +                  test_reconnect  if !ON_MINGW  noinst_PROGRAMS += test_shutdown_stress \ @@ -29,6 +30,7 @@ test_reqrep_device_SOURCES = test_reqrep_device.cpp  test_sub_forward_SOURCES = test_sub_forward.cpp  test_invalid_rep_SOURCES = test_invalid_rep.cpp  test_msg_flags_SOURCES = test_msg_flags.cpp +test_reconnect_SOURCES = test_reconnect.cpp  if !ON_MINGW  test_shutdown_stress_SOURCES = test_shutdown_stress.cpp diff --git a/tests/test_reconnect.cpp b/tests/test_reconnect.cpp new file mode 100644 index 0000000..af1b3c1 --- /dev/null +++ b/tests/test_reconnect.cpp @@ -0,0 +1,64 @@ +/* +    Copyright (c) 2012 250bpm s.r.o. +    Copyright (c) 2012 Other contributors as noted in the AUTHORS file + +    This file is part of Crossroads project. + +    Crossroads is free software; you can redistribute it and/or modify it under +    the terms of the GNU Lesser General Public License as published by +    the Free Software Foundation; either version 3 of the License, or +    (at your option) any later version. + +    Crossroads 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 <assert.h> +#include <stdio.h> + +#include "../include/xs.h" +#include "../include/xs_utils.h" + +int main (int argc, char *argv []) +{ +    fprintf (stderr, "test_reconnect running...\n"); + +    //  Create the basic infrastructure. +    void *ctx = xs_init (1); +    assert (ctx); +    void *push = xs_socket (ctx, XS_PUSH); +    assert (push); +    void *pull = xs_socket (ctx, XS_PULL); +    assert (push); + +    //  Connect before bind was done at the peer and send one message. +    int rc = xs_connect (push, "tcp://127.0.0.1:5560"); +    assert (rc == 0); +    rc = xs_send (push, "ABC", 3, 0); +    assert (rc == 3); + +    //  Wait a while for few attempts to reconnect to happen. +    xs_sleep (1); + +    //  Bind the peer and get the message. +    rc = xs_bind (pull, "tcp://127.0.0.1:5560"); +    assert (rc == 0); +    unsigned char buf [3]; +    rc = xs_recv (pull, buf, sizeof (buf), 0); +    assert (rc == 3); + +    //  Clean up. +    rc = xs_close (push); +    assert (rc == 0); +    rc = xs_close (pull); +    assert (rc == 0); +    rc = xs_term (ctx); +    assert (rc == 0); + +    return 0 ; +} | 
