1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
|
suppressPackageStartupMessages(library(pbdZMQ))
### zmq interface
### In general and separate files
# server_context = zmq.ctx.new()
# server_socket = zmq.socket(server_context, ZMQ.ST()$REP)
# client_context = zmq.ctx.new()
# client_socket = zmq.socket(client_context, ZMQ.ST()$REQ)
### Server file
# zmq.setsockopt(server_socket, ZMQ.SO()$CONNECT_TIMEOUT, 1000L)
# zmq.setsockopt(server_socket, ZMQ.SO()$RCVTIMEO, 1000L)
# zmq.setsockopt(server_socket, ZMQ.SO()$SNDTIMEO, 1000L)
# zmq.bind(server_socket, "tcp://*:55555")
### client file
# zmq.setsockopt(client_socket, ZMQ.SO()$CONNECT_TIMEOUT, 1000L)
# zmq.setsockopt(client_socket, ZMQ.SO()$RCVTIMEO, 1000L)
# zmq.setsockopt(client_socket, ZMQ.SO()$SNDTIMEO, 1000L)
# zmq.connect(client_socket, "tcp://localhost:55555")
### For CRAN testing in local (the same process) only to avoid block
cran_context = zmq.ctx.new()
server_socket = zmq.socket(cran_context, ZMQ.ST()$REP)
client_socket = zmq.socket(cran_context, ZMQ.ST()$REQ)
### Server
zmq.bind(server_socket, "inproc://#1")
### client
zmq.connect(client_socket, "inproc://#1")
### Test pbdZMQ
tester = function(indata)
{
zmq.msg.send(indata, client_socket)
c2s <- zmq.msg.recv(server_socket)
stopifnot(all.equal(c2s, indata))
zmq.send(server_socket, "ok")
s2c <- zmq.recv(client_socket)
stopifnot(all.equal(s2c$buf, "ok"))
}
tester("test")
tester(1:5)
zmq.close(server_socket)
zmq.close(client_socket)
|