Module Name:    src
Committed By:   christos
Date:           Sun Jan  6 00:35:22 UTC 2013

Modified Files:
        src/tests/net/net: Makefile
Added Files:
        src/tests/net/net: t_udp.c

Log Message:
new udp test


To generate a diff of this commit:
cvs rdiff -u -r1.3 -r1.4 src/tests/net/net/Makefile
cvs rdiff -u -r0 -r1.1 src/tests/net/net/t_udp.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/tests/net/net/Makefile
diff -u src/tests/net/net/Makefile:1.3 src/tests/net/net/Makefile:1.4
--- src/tests/net/net/Makefile:1.3	Wed Sep 28 19:11:12 2011
+++ src/tests/net/net/Makefile	Sat Jan  5 19:35:22 2013
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.3 2011/09/28 23:11:12 christos Exp $
+# $NetBSD: Makefile,v 1.4 2013/01/06 00:35:22 christos Exp $
 #
 
 .include <bsd.own.mk>
@@ -7,6 +7,7 @@ TESTSDIR=	${TESTSBASE}/net/net
 
 TESTS_C=	t_raw
 TESTS_C+=	t_unix
+TESTS_C+=	t_udp
 
 LDADD.t_raw+=		-lrumpnet_local -lrumpnet_netinet -lrumpnet_net
 LDADD.t_raw+=		-lrumpnet -lrumpvfs -lrump -lrumpuser -lpthread

Added files:

Index: src/tests/net/net/t_udp.c
diff -u /dev/null src/tests/net/net/t_udp.c:1.1
--- /dev/null	Sat Jan  5 19:35:22 2013
+++ src/tests/net/net/t_udp.c	Sat Jan  5 19:35:22 2013
@@ -0,0 +1,110 @@
+#include <sys/cdefs.h>
+__RCSID("$NetBSD: t_udp.c,v 1.1 2013/01/06 00:35:22 christos Exp $");
+
+#include <sys/socket.h>
+#include <netinet/in.h>
+
+#include <netdb.h>
+#include <string.h>
+#include <errno.h>
+#include <unistd.h>
+
+#include <atf-c.h>
+
+static const char msg[] = "sendto test";
+
+static void
+sendit(int family)
+{
+	struct addrinfo hints;
+	struct addrinfo *res;
+	int             S, s;
+	int             e;
+
+	/* lookup localhost addr, depending on argv[1] */
+	memset(&hints, 0, sizeof(hints));
+	hints.ai_family = family;
+	hints.ai_socktype = SOCK_DGRAM;
+	hints.ai_protocol = IPPROTO_UDP;
+	hints.ai_flags = 0;
+
+	e = getaddrinfo("localhost", "9999", &hints, &res);
+	ATF_REQUIRE_MSG(e == 0, "getaddrinfo AF=%d: %s", family,
+	    gai_strerror(e));
+
+	/* server socket */
+	S = socket(res->ai_family, res->ai_socktype, res->ai_protocol);
+	ATF_REQUIRE_MSG(S >= 0, "server-socket AF=%d: %s", family,
+	    strerror(errno));
+
+	e = bind(S, res->ai_addr, res->ai_addrlen);
+	ATF_REQUIRE_MSG(e == 0, "bind AF=%d: %s", family,
+	    strerror(errno));
+
+	/* client socket */
+	s = socket(res->ai_family, res->ai_socktype, res->ai_protocol);
+	ATF_REQUIRE_MSG(s >= 0, "client-socket AF=%d: %s", family,
+	    strerror(errno));
+
+	/* sendto */
+	e = sendto(s, msg, sizeof(msg), 0, res->ai_addr, res->ai_addrlen);
+	ATF_REQUIRE_MSG(e == sizeof(msg), "sendto(1) AF=%d: %s", family,
+	    strerror(errno));
+
+	e = sendto(s, msg, sizeof(msg), 0, res->ai_addr, res->ai_addrlen);
+	ATF_REQUIRE_MSG(e == sizeof(msg), "sendto(2) AF=%d: %s", family,
+	    strerror(errno));
+
+	/* connect + send */
+	e = connect(s, res->ai_addr, res->ai_addrlen);
+	ATF_REQUIRE_MSG(e == 0, "connect(1) AF=%d: %s", family,
+	    strerror(errno));
+
+	e = send(s, msg, sizeof(msg), 0);
+	ATF_REQUIRE_MSG(e == sizeof(msg), "send(1) AF=%d: %s", family,
+	    strerror(errno));
+
+	e = connect(s, res->ai_addr, res->ai_addrlen);
+	ATF_REQUIRE_MSG(e == 0, "connect(1) AF=%d: %s", family,
+	    strerror(errno));
+
+	e = send(s, msg, sizeof(msg), 0);
+	ATF_REQUIRE_MSG(e == sizeof(msg), "send(1) AF=%d: %s", family,
+	    strerror(errno));
+
+	close(s);
+}
+
+ATF_TC(udp4_send);
+ATF_TC_HEAD(udp4_send, tc)
+{
+
+	atf_tc_set_md_var(tc, "descr", "Check that inet4 udp send works both"
+	    " for connected and unconnected sockets");
+}
+
+ATF_TC_BODY(udp4_send, tc)
+{
+	sendit(AF_INET);
+}
+
+ATF_TC(udp6_send);
+ATF_TC_HEAD(udp6_send, tc)
+{
+
+	atf_tc_set_md_var(tc, "descr", "Check that inet6 udp send works both"
+	    " for connected and unconnected sockets");
+}
+
+ATF_TC_BODY(udp6_send, tc)
+{
+	sendit(AF_INET6);
+}
+
+ATF_TP_ADD_TCS(tp)
+{
+
+	ATF_TP_ADD_TC(tp, udp4_send);
+	ATF_TP_ADD_TC(tp, udp6_send);
+	return atf_no_error();
+}

Reply via email to