test_timeo.cpp 2.46 KB
Newer Older
1
/*
2
    Copyright (c) 2007-2013 Contributors as noted in the AUTHORS file
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19

    This file is part of 0MQ.

    0MQ 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.

    0MQ 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/>.
*/

20
#include "../include/zmq.h"
21
#include <sys/time.h>
22
#include <stdio.h>
23 24 25
#include <string.h>
#undef NDEBUG
#include <assert.h>
26 27


28
int main (void)
29
{
30
    void *ctx = zmq_ctx_new ();
31 32
    assert (ctx);

33 34 35
    void *frontend = zmq_socket (ctx, ZMQ_DEALER);
    assert (frontend);
    int rc = zmq_bind (frontend, "inproc://timeout_test");
36 37
    assert (rc == 0);

38 39 40
    //  Receive on disconnected socket returns immediately
    char buffer [32];
    rc = zmq_recv (frontend, buffer, 32, ZMQ_DONTWAIT);
41 42
    assert (rc == -1);
    assert (zmq_errno() == EAGAIN);
43 44 45 46 47
    
    //  Check whether receive timeout is honored
    int timeout = 250;
    rc = zmq_setsockopt (frontend, ZMQ_RCVTIMEO, &timeout, sizeof (int));
    assert (rc == 0);
48

49 50 51
    struct timeval before, after;
    gettimeofday (&before, NULL);
    rc = zmq_recv (frontend, buffer, 32, 0);
52 53
    assert (rc == -1);
    assert (zmq_errno () == EAGAIN);
54 55 56 57 58 59 60 61 62 63 64 65
    gettimeofday (&after, NULL);

    long elapsed = (long)
        ((after.tv_sec * 1000 + after.tv_usec / 1000)
      - (before.tv_sec * 1000 + before.tv_usec / 1000));
        
    assert (elapsed > 200 && elapsed < 300);

    //  Check that normal message flow works as expected
    void *backend = zmq_socket (ctx, ZMQ_DEALER);
    assert (backend);
    rc = zmq_connect (backend, "inproc://timeout_test");
66
    assert (rc == 0);
67
    rc = zmq_setsockopt (backend, ZMQ_SNDTIMEO, &timeout, sizeof (int));
68 69
    assert (rc == 0);

70 71 72 73
    rc = zmq_send (backend, "Hello", 5, 0);
    assert (rc == 5);
    rc = zmq_recv (frontend, buffer, 32, 0);
    assert (rc == 5);
74

75 76
    //  Clean-up
    rc = zmq_close (backend);
77
    assert (rc == 0);
78 79
    
    rc = zmq_close (frontend);
80
    assert (rc == 0);
81
    
82
    rc = zmq_ctx_term (ctx);
83 84 85 86
    assert (rc == 0);

    return 0 ;
}