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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
+
+
-
+
+
+
+
+
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
-
-
+
+
-
-
-
-
+
+
+
-
-
-
-
+
+
+
+
+
+
+
+
+
+
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
|
(import (chicken io)
(chicken string)
(chicken process-context)
(chicken process-context posix)
miscmacros
nng
srfi-18
test)
test
matchable
typed-records)
(define help "Usage: nng-test COMMAND
where COMMAND is one of:
dotest : run the basic req/rep test
")
(define address-tcp-1 "tcp://localhost:5555")
(define address-tcp-2 "tcp://localhost:6666")
(define address-tls+tcp-1 "tls+tcp://localhost:5555")
(define address-inproc-1 "inproc://local1")
(define address-inproc-2 "inproc://local2")
(tls-register!)
(define cert
(if (tls-enabled?)
(with-input-from-file "cert.pem"
(lambda ()
(read-string)))
#f))
(define key
(if (tls-enabled?)
(with-input-from-file "key.pem"
(lambda ()
(read-string)))
#f))
;;;
;;; Req-Rep
;;;
(define (make-listening-reply-socket address)
(let ((socket (make-rep-socket)))
(socket-set! socket 'nng/recvtimeo 2000)
(nng-listen socket address)
socket))
(define (make-dialed-request-socket address)
(let ((socket (make-req-socket)))
(socket-set! socket 'nng/recvtimeo 2000)
(nng-dial socket address)
socket))
(define (req-rep-test address)
(let ((rep (make-listening-reply-socket address))
(req (make-dialed-request-socket address)))
(nng-send req "message")
(nng-send req "message 1")
(nng-recv rep)
(nng-send rep "message")
(begin0
(nng-recv req)
(nng-close! rep))))
(test-group "nng"
(define (do-test)
(test-group "nng"
(test "tcp req-rep"
"message"
(req-rep-test address-tcp-1))
(test "tcp req-rep"
"message"
(req-rep-test address-tcp-1))
(test "inproc req-rep"
"message"
(req-rep-test address-inproc-1))
(test "inproc req-rep"
"message"
(req-rep-test address-inproc-1)))
(test-exit))
(defstruct srv
myaddr
remaddr
req
rep
name)
)
(define (server-setup myname myaddr remoteaddr)
(let* ((srvdat (make-srv)))
(srv-myaddr-set! srvdat myaddr)
(srv-remaddr-set! srvdat remoteaddr)
(srv-rep-set! srvdat (make-listening-reply-socket myaddr))
(srv-req-set! srvdat (make-dialed-request-socket myaddr))
(srv-name-set! srvdat myname)
srvdat))
(define (send-n-messages n srvdat)
(let* ((name (srv-name srvdat)))
(let loop ((i 0))
(if (< i n)
(begin
(print "send: "(nng-send (srv-req srvdat) (conc name "-" i)))
(print "receive: "(nng-recv (srv-rep srvdat)))
(loop (+ i 1)))))))
(test-exit)
(define (close-srv srvdat)
(nng-close! (srv-rep srvdat)))
(match
(command-line-arguments)
(("do-test")(do-test))
(("send-n" n myaddr toaddr)
(let ((n-num (string->number n))
(sdat (server-setup "just testing" myaddr toaddr)))
(send-n-messages n-num sdat)
(close-srv sdat)))
((cmd)(print "ERROR: command "cmd", not recognised.\n\n"help))
(else
(print help)))
|