summaryrefslogtreecommitdiffstats
path: root/bin/tests/sockaddr
diff options
context:
space:
mode:
authorMartin Nagy <mnagy@redhat.com>2009-02-11 20:37:59 +0100
committerMartin Nagy <mnagy@redhat.com>2009-02-11 20:37:59 +0100
commitf50ae72ec3417cae55dd4e085991c01af9fdc5f1 (patch)
tree0e36c9a3320f6d068df93d3ff6d84b821d23db40 /bin/tests/sockaddr
downloadbind_dynamic-start.tar.gz
bind_dynamic-start.tar.xz
bind_dynamic-start.zip
Initial commitstart
Diffstat (limited to 'bin/tests/sockaddr')
-rw-r--r--bin/tests/sockaddr/Makefile.in55
-rw-r--r--bin/tests/sockaddr/t_sockaddr.c137
2 files changed, 192 insertions, 0 deletions
diff --git a/bin/tests/sockaddr/Makefile.in b/bin/tests/sockaddr/Makefile.in
new file mode 100644
index 0000000..f0dbbfb
--- /dev/null
+++ b/bin/tests/sockaddr/Makefile.in
@@ -0,0 +1,55 @@
+# Copyright (C) 2004, 2007 Internet Systems Consortium, Inc. ("ISC")
+# Copyright (C) 1999-2002 Internet Software Consortium.
+#
+# Permission to use, copy, modify, and/or distribute this software for any
+# purpose with or without fee is hereby granted, provided that the above
+# copyright notice and this permission notice appear in all copies.
+#
+# THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
+# REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
+# AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
+# INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
+# LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
+# OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+# PERFORMANCE OF THIS SOFTWARE.
+
+# $Id: Makefile.in,v 1.21 2007/06/19 23:47:00 tbox Exp $
+
+srcdir = @srcdir@
+VPATH = @srcdir@
+top_srcdir = @top_srcdir@
+
+@BIND9_MAKE_INCLUDES@
+
+CINCLUDES = ${TEST_INCLUDES} ${ISC_INCLUDES}
+
+CDEFINES =
+CWARNINGS =
+
+ISCLIBS = ../../../lib/isc/libisc.@A@
+TAPIDEPLIBS = ../../../lib/tests/libt_api.@A@
+
+ISCDEPLIBS = ../../../lib/isc/libisc.@A@
+TAPILIBS = ../../../lib/tests/libt_api.@A@
+
+DEPLIBS = ${TAPIDEPLIBS} ${ISCDEPLIBS}
+
+LIBS = ${TAPILIBS} ${ISCLIBS} @LIBS@
+
+TARGETS = t_sockaddr@EXEEXT@
+
+SRCS = t_sockaddr.c
+
+@BIND9_MAKE_RULES@
+
+t_sockaddr@EXEEXT@: t_sockaddr.@O@ ${DEPLIBS}
+ ${LIBTOOL_MODE_LINK} ${PURIFY} ${CC} ${CFLAGS} ${LDFLAGS} -o $@ t_sockaddr.@O@ ${LIBS}
+
+test: t_sockaddr@EXEEXT@
+ -@./t_sockaddr@EXEEXT@ -b @srcdir@ -a
+
+testhelp:
+ @./t_sockaddr@EXEEXT@ -h
+
+clean distclean::
+ rm -f ${TARGETS}
diff --git a/bin/tests/sockaddr/t_sockaddr.c b/bin/tests/sockaddr/t_sockaddr.c
new file mode 100644
index 0000000..46003f1
--- /dev/null
+++ b/bin/tests/sockaddr/t_sockaddr.c
@@ -0,0 +1,137 @@
+/*
+ * Copyright (C) 2004, 2007 Internet Systems Consortium, Inc. ("ISC")
+ * Copyright (C) 1999-2001 Internet Software Consortium.
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
+ * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
+ * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
+ * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
+ * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
+ * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
+ * PERFORMANCE OF THIS SOFTWARE.
+ */
+
+/* $Id: t_sockaddr.c,v 1.14 2007/06/19 23:47:00 tbox Exp $ */
+
+#include <config.h>
+
+#include <isc/netaddr.h>
+#include <isc/result.h>
+#include <isc/sockaddr.h>
+
+#include <tests/t_api.h>
+
+static int
+test_isc_sockaddr_eqaddrprefix(void) {
+ struct in_addr ina_a;
+ struct in_addr ina_b;
+ struct in_addr ina_c;
+ isc_sockaddr_t isa_a;
+ isc_sockaddr_t isa_b;
+ isc_sockaddr_t isa_c;
+
+ if (inet_pton(AF_INET, "194.100.32.87", &ina_a) < 0)
+ return T_FAIL;
+ if (inet_pton(AF_INET, "194.100.32.80", &ina_b) < 0)
+ return T_FAIL;
+ if (inet_pton(AF_INET, "194.101.32.87", &ina_c) < 0)
+ return T_FAIL;
+ isc_sockaddr_fromin(&isa_a, &ina_a, 0);
+ isc_sockaddr_fromin(&isa_b, &ina_b, 42);
+ isc_sockaddr_fromin(&isa_c, &ina_c, 0);
+
+ if (isc_sockaddr_eqaddrprefix(&isa_a, &isa_b, 0) != ISC_TRUE)
+ return T_FAIL;
+ if (isc_sockaddr_eqaddrprefix(&isa_a, &isa_b, 29) != ISC_TRUE)
+ return T_FAIL;
+ if (isc_sockaddr_eqaddrprefix(&isa_a, &isa_b, 30) != ISC_FALSE)
+ return T_FAIL;
+ if (isc_sockaddr_eqaddrprefix(&isa_a, &isa_b, 32) != ISC_FALSE)
+ return T_FAIL;
+ if (isc_sockaddr_eqaddrprefix(&isa_a, &isa_c, 8) != ISC_TRUE)
+ return T_FAIL;
+ if (isc_sockaddr_eqaddrprefix(&isa_a, &isa_c, 16) != ISC_FALSE)
+ return T_FAIL;
+
+ return T_PASS;
+}
+
+static void
+t1(void) {
+ int result;
+ t_assert("isc_sockaddr_eqaddrprefix", 1, T_REQUIRED,
+ "isc_sockaddr_eqaddrprefix() returns ISC_TRUE when "
+ "prefixes of a and b are equal, and ISC_FALSE when "
+ "they are not equal");
+ result = test_isc_sockaddr_eqaddrprefix();
+ t_result(result);
+}
+
+static int
+test_isc_netaddr_masktoprefixlen(void) {
+ struct in_addr na_a;
+ struct in_addr na_b;
+ struct in_addr na_c;
+ struct in_addr na_d;
+ isc_netaddr_t ina_a;
+ isc_netaddr_t ina_b;
+ isc_netaddr_t ina_c;
+ isc_netaddr_t ina_d;
+ unsigned int plen;
+
+ if (inet_pton(AF_INET, "0.0.0.0", &na_a) < 0)
+ return T_FAIL;
+ if (inet_pton(AF_INET, "255.255.255.254", &na_b) < 0)
+ return T_FAIL;
+ if (inet_pton(AF_INET, "255.255.255.255", &na_c) < 0)
+ return T_FAIL;
+ if (inet_pton(AF_INET, "255.255.255.0", &na_d) < 0)
+ return T_FAIL;
+ isc_netaddr_fromin(&ina_a, &na_a);
+ isc_netaddr_fromin(&ina_b, &na_b);
+ isc_netaddr_fromin(&ina_c, &na_c);
+ isc_netaddr_fromin(&ina_d, &na_d);
+
+ if (isc_netaddr_masktoprefixlen(&ina_a, &plen) != ISC_R_SUCCESS)
+ return T_FAIL;
+ if (plen != 0)
+ return T_FAIL;
+
+ if (isc_netaddr_masktoprefixlen(&ina_b, &plen) != ISC_R_SUCCESS)
+ return T_FAIL;
+ if (plen != 31)
+ return T_FAIL;
+
+ if (isc_netaddr_masktoprefixlen(&ina_c, &plen) != ISC_R_SUCCESS)
+ return T_FAIL;
+ if (plen != 32)
+ return T_FAIL;
+
+ if (isc_netaddr_masktoprefixlen(&ina_d, &plen) != ISC_R_SUCCESS)
+ return T_FAIL;
+ if (plen != 24)
+ return T_FAIL;
+
+ return T_PASS;
+}
+
+static void
+t2(void) {
+ int result;
+ t_assert("isc_netaddr_masktoprefixlen", 1, T_REQUIRED,
+ "isc_netaddr_masktoprefixlen() calculates "
+ "correct prefix lengths ");
+ result = test_isc_netaddr_masktoprefixlen();
+ t_result(result);
+}
+
+testspec_t T_testlist[] = {
+ { t1, "isc_sockaddr_eqaddrprefix" },
+ { t2, "isc_netaddr_masktoprefixlen" },
+ { NULL, NULL }
+};
+