1 /* $NetBSD: t_rpc.c,v 1.10 2016/08/27 14:36:22 christos Exp $ */
4 __RCSID("$NetBSD: t_rpc.c,v 1.10 2016/08/27 14:36:22 christos Exp $");
7 #include <sys/socket.h>
20 #define ERRX(ev, msg, ...) ATF_REQUIRE_MSG(0, msg, __VA_ARGS__)
22 #define SKIPX(ev, msg, ...) do { \
23 atf_tc_skip(msg, __VA_ARGS__); \
25 } while(/*CONSTCOND*/0)
28 #define ERRX(ev, msg, ...) errx(EXIT_FAILURE, msg, __VA_ARGS__)
29 #define SKIPX(ev, msg, ...) errx(EXIT_FAILURE, msg, __VA_ARGS__)
33 #define DPRINTF(...) printf(__VA_ARGS__)
39 #define RPCBPROC_NULL 0
42 reply(caddr_t replyp, struct netbuf * raddrp, struct netconfig * nconf)
44 char host[NI_MAXHOST];
45 struct sockaddr *sock = raddrp->buf;
49 error = getnameinfo(sock, sock->sa_len, host, sizeof(host), NULL, 0, 0);
51 warnx("Cannot resolve address (%s)", gai_strerror(error));
53 printf("response from: %s\n", host);
58 #define __rpc_control rpc_control
61 extern bool_t __rpc_control(int, void *);
64 onehost(const char *host, const char *transp)
75 #define CLCR_SET_RPCB_TIMEOUT 2
76 __rpc_control(CLCR_SET_RPCB_TIMEOUT, &tv);
78 if ((clnt = clnt_create(host, RPCBPROG, RPCBVERS, transp)) == NULL)
79 SKIPX(, "clnt_create (%s)", clnt_spcreateerror(""));
84 if (clnt_call(clnt, RPCBPROC_NULL, (xdrproc_t)xdr_void, NULL,
85 (xdrproc_t)xdr_void, NULL, tv)
88 if (clnt_call(clnt, RPCBPROC_NULL, xdr_void, NULL, xdr_void, NULL, tv)
91 ERRX(, "clnt_call (%s)", clnt_sperror(clnt, ""));
92 clnt_control(clnt, CLGET_SVC_ADDR, (char *) &addr);
93 reply(NULL, &addr, NULL);
101 static struct timeval tout = {1, 0};
104 server(struct svc_req *rqstp, SVCXPRT *transp)
108 DPRINTF("Starting server\n");
110 switch (rqstp->rq_proc) {
112 if (!svc_sendreply(transp, (xdrproc_t)xdr_void, NULL))
113 ERRX(, "svc_sendreply failed %d", 0);
118 if (!svc_sendreply(transp, (xdrproc_t)xdr_void, NULL))
119 ERRX(, "svc_sendreply failed %d", 0);
123 svcerr_noproc(transp);
127 if (!svc_getargs(transp, (xdrproc_t)xdr_int, (void *)&num)) {
128 svcerr_decode(transp);
131 DPRINTF("About to increment\n");
133 if (!svc_sendreply(transp, (xdrproc_t)xdr_int, (void *)&num))
134 ERRX(, "svc_sendreply failed %d", 1);
135 DPRINTF("Leaving server procedure.\n");
139 rawtest(const char *arg)
151 svc = svc_raw_create();
153 ERRX(EXIT_FAILURE, "Cannot create server %d", num);
154 if (!svc_reg(svc, PROGNUM, VERSNUM, server, NULL))
155 ERRX(EXIT_FAILURE, "Cannot register server %d", num);
157 clnt = clnt_raw_create(PROGNUM, VERSNUM);
159 ERRX(EXIT_FAILURE, "%s",
160 clnt_spcreateerror("clnt_raw_create"));
161 rv = clnt_call(clnt, PLUSONE, (xdrproc_t)xdr_int, (void *)&num,
162 (xdrproc_t)xdr_int, (void *)&resp, tout);
163 if (rv != RPC_SUCCESS)
164 ERRX(EXIT_FAILURE, "clnt_call: %s", clnt_sperrno(rv));
165 DPRINTF("Got %d\n", resp);
169 ERRX(EXIT_FAILURE, "expected %d got %d", num, resp);
175 regtest(const char *hostname, const char *transp, const char *arg, int p)
188 svc_fdset_init(p ? SVC_FDSET_POLL : 0);
190 if (!svc_create(server, PROGNUM, VERSNUM, transp))
192 SKIPX(EXIT_FAILURE, "Cannot create server %d", num);
195 switch ((pid = fork())) {
197 DPRINTF("Calling svc_run\n");
199 ERRX(EXIT_FAILURE, "svc_run returned %d!", num);
201 ERRX(EXIT_FAILURE, "Fork failed (%s)", strerror(errno));
207 DPRINTF("Initializing client\n");
208 clnt = clnt_create(hostname, PROGNUM, VERSNUM, transp);
210 ERRX(EXIT_FAILURE, "%s",
211 clnt_spcreateerror("clnt_raw_create"));
212 rv = clnt_call(clnt, PLUSONE, (xdrproc_t)xdr_int, (void *)&num,
213 (xdrproc_t)xdr_int, (void *)&resp, tout);
214 if (rv != RPC_SUCCESS)
215 ERRX(EXIT_FAILURE, "clnt_call: %s", clnt_sperrno(rv));
216 DPRINTF("Got %d\n", resp);
218 ERRX(EXIT_FAILURE, "expected %d got %d", num, resp);
219 rv = clnt_call(clnt, DESTROY, (xdrproc_t)xdr_void, NULL,
220 (xdrproc_t)xdr_void, NULL, tout);
221 if (rv != RPC_SUCCESS)
222 ERRX(EXIT_FAILURE, "clnt_call: %s", clnt_sperrno(rv));
231 allhosts(const char *transp)
233 enum clnt_stat clnt_stat;
235 clnt_stat = rpc_broadcast(RPCBPROG, RPCBVERS, RPCBPROC_NULL,
236 (xdrproc_t)xdr_void, NULL, (xdrproc_t)xdr_void,
237 NULL, (resultproc_t)reply, transp);
238 if (clnt_stat != RPC_SUCCESS && clnt_stat != RPC_TIMEDOUT)
239 ERRX(EXIT_FAILURE, "%s", clnt_sperrno(clnt_stat));
243 main(int argc, char *argv[])
247 const char *transp = "udp";
250 while ((ch = getopt(argc, argv, "prstu")) != -1)
269 "Usage: %s -[r|s|t|u] [<hostname>...]\n",
274 if (argc == optind) {
280 for (; optind < argc; optind++) {
283 onehost(argv[optind], transp) :
284 regtest(argv[optind], transp, "1", p);
286 rawtest(argv[optind]);
295 ATF_TC(get_svc_addr_tcp);
296 ATF_TC_HEAD(get_svc_addr_tcp, tc)
298 atf_tc_set_md_var(tc, "descr", "Checks CLGET_SVC_ADDR for tcp");
302 ATF_TC_BODY(get_svc_addr_tcp, tc)
304 onehost("localhost", "tcp");
308 ATF_TC(get_svc_addr_udp);
309 ATF_TC_HEAD(get_svc_addr_udp, tc)
311 atf_tc_set_md_var(tc, "descr", "Checks CLGET_SVC_ADDR for udp");
314 ATF_TC_BODY(get_svc_addr_udp, tc)
316 onehost("localhost", "udp");
323 atf_tc_set_md_var(tc, "descr", "Checks svc raw");
335 atf_tc_set_md_var(tc, "descr", "Checks svc tcp (select)");
337 atf_tc_set_md_var(tc, "require.user", "root");
343 regtest("localhost", "tcp", "1", 0);
350 atf_tc_set_md_var(tc, "descr", "Checks svc udp (select)");
352 atf_tc_set_md_var(tc, "require.user", "root");
358 regtest("localhost", "udp", "1", 0);
363 ATF_TC_HEAD(tcp_poll, tc)
365 atf_tc_set_md_var(tc, "descr", "Checks svc tcp (poll)");
367 atf_tc_set_md_var(tc, "require.user", "root");
371 ATF_TC_BODY(tcp_poll, tc)
373 regtest("localhost", "tcp", "1", 1);
378 ATF_TC_HEAD(udp_poll, tc)
380 atf_tc_set_md_var(tc, "descr", "Checks svc udp (poll)");
382 atf_tc_set_md_var(tc, "require.user", "root");
386 ATF_TC_BODY(udp_poll, tc)
388 regtest("localhost", "udp", "1", 1);
394 ATF_TP_ADD_TC(tp, get_svc_addr_udp);
395 ATF_TP_ADD_TC(tp, get_svc_addr_tcp);
396 ATF_TP_ADD_TC(tp, raw);
397 ATF_TP_ADD_TC(tp, tcp);
398 ATF_TP_ADD_TC(tp, udp);
399 ATF_TP_ADD_TC(tp, tcp_poll);
400 ATF_TP_ADD_TC(tp, udp_poll);
402 return atf_no_error();