test_hwm.cpp 2.29 KB
Newer Older
Mikko Koppanen's avatar
Mikko Koppanen committed
1
/*
2 3
    Copyright (c) 2010-2011 250bpm s.r.o.
    Copyright (c) 2010-2011 Other contributors as noted in the AUTHORS file
Mikko Koppanen's avatar
Mikko Koppanen committed
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21

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


22
#include "../include/zmq.h"
23
#include <stdio.h>
24 25 26
#include <string.h>
#undef NDEBUG
#include <assert.h>
Mikko Koppanen's avatar
Mikko Koppanen committed
27

28
int main (void)
Mikko Koppanen's avatar
Mikko Koppanen committed
29
{
30
    void *ctx = zmq_ctx_new ();
31 32 33 34 35 36
    assert (ctx);

    //  Create pair of socket, each with high watermark of 2. Thus the total
    //  buffer space should be 4 messages.
    void *sb = zmq_socket (ctx, ZMQ_PULL);
    assert (sb);
37
    int hwm = 2;
38
    int rc = zmq_setsockopt (sb, ZMQ_RCVHWM, &hwm, sizeof (hwm));
39 40 41 42 43 44
    assert (rc == 0);
    rc = zmq_bind (sb, "inproc://a");
    assert (rc == 0);

    void *sc = zmq_socket (ctx, ZMQ_PUSH);
    assert (sc);
45
    rc = zmq_setsockopt (sc, ZMQ_SNDHWM, &hwm, sizeof (hwm));
46 47 48 49 50
    assert (rc == 0);
    rc = zmq_connect (sc, "inproc://a");
    assert (rc == 0);

    //  Try to send 10 messages. Only 4 should succeed.
Mikko Koppanen's avatar
Mikko Koppanen committed
51 52
    for (int i = 0; i < 10; i++)
    {
53
        int rc = zmq_send (sc, NULL, 0, ZMQ_DONTWAIT);
54 55 56
        if (i < 4)
            assert (rc == 0);
        else
57
            assert (rc < 0 && errno == EAGAIN);
58
    }
Mikko Koppanen's avatar
Mikko Koppanen committed
59

60 61
    // There should be now 4 messages pending, consume them.
    for (int i = 0; i != 4; i++) {
62
        rc = zmq_recv (sb, NULL, 0, 0);
63 64
        assert (rc == 0);
    }
Mikko Koppanen's avatar
Mikko Koppanen committed
65

66
    // Now it should be possible to send one more.
67
    rc = zmq_send (sc, NULL, 0, 0);
68 69 70
    assert (rc == 0);

    //  Consume the remaining message.
71
    rc = zmq_recv (sb, NULL, 0, 0);
72 73 74 75 76 77 78 79
    assert (rc == 0);

    rc = zmq_close (sc);
    assert (rc == 0);

    rc = zmq_close (sb);
    assert (rc == 0);

80
    rc = zmq_ctx_term (ctx);
81
    assert (rc == 0);
Mikko Koppanen's avatar
Mikko Koppanen committed
82 83 84

	return 0;
}