Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/regress/lib/libc regress test for getaddrinfo/getnameinfo.



details:   https://anonhg.NetBSD.org/src/rev/b7afaf86bbb0
branches:  trunk
changeset: 533626:b7afaf86bbb0
user:      itojun <itojun%NetBSD.org@localhost>
date:      Fri Jul 05 15:42:41 2002 +0000

description:
regress test for getaddrinfo/getnameinfo.

diffstat:

 regress/lib/libc/Makefile                 |    6 +-
 regress/lib/libc/getaddrinfo/Makefile     |   17 +++
 regress/lib/libc/getaddrinfo/answer       |  104 ++++++++++++++++++++
 regress/lib/libc/getaddrinfo/gaitest.c    |  149 ++++++++++++++++++++++++++++++
 regress/lib/libc/getaddrinfo/testsuite.sh |   58 +++++++++++
 5 files changed, 331 insertions(+), 3 deletions(-)

diffs (truncated from 358 to 300 lines):

diff -r 13b6b4513bb2 -r b7afaf86bbb0 regress/lib/libc/Makefile
--- a/regress/lib/libc/Makefile Fri Jul 05 14:29:06 2002 +0000
+++ b/regress/lib/libc/Makefile Fri Jul 05 15:42:41 2002 +0000
@@ -1,7 +1,7 @@
-#      $NetBSD: Makefile,v 1.28 2002/04/21 20:22:12 bjh21 Exp $
+#      $NetBSD: Makefile,v 1.29 2002/07/05 15:42:41 itojun Exp $
 
-SUBDIR+= _setjmp clone db div divrem                           \
-       gen hsearch int_fmtio md5sha popen regex rpc            \
+SUBDIR+= _setjmp clone db div divrem \
+       gen getaddrinfo hsearch int_fmtio md5sha popen regex rpc \
        setjmp sigsetjmp string sys time
 .if (${MACHINE_ARCH} != "vax" && ${MACHINE_ARCH} != "m68000")
 SUBDIR+= ieeefp
diff -r 13b6b4513bb2 -r b7afaf86bbb0 regress/lib/libc/getaddrinfo/Makefile
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/regress/lib/libc/getaddrinfo/Makefile     Fri Jul 05 15:42:41 2002 +0000
@@ -0,0 +1,17 @@
+#      $NetBSD: Makefile,v 1.1 2002/07/05 15:42:42 itojun Exp $
+
+PROG=          gaitest
+SRCS=          gaitest.c
+NOMAN=         # defined
+CLEANFILES+=   out
+
+regress: ${PROG}
+       sh ${.CURDIR}/testsuite.sh >out 2>&1
+       @if diff -u out ${.CURDIR}/answer; then \
+               echo SUCCESS; \
+       else \
+               echo FAIL; \
+               exit 1; \
+       fi
+
+.include <bsd.prog.mk>
diff -r 13b6b4513bb2 -r b7afaf86bbb0 regress/lib/libc/getaddrinfo/answer
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/regress/lib/libc/getaddrinfo/answer       Fri Jul 05 15:42:41 2002 +0000
@@ -0,0 +1,104 @@
+== basic ones
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host ::1 serv http
+ai1: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv www
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host 127.0.0.1 serv http
+ai1: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv www
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host localhost serv http
+ai1: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv www cname "localhost"
+ai2: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv www cname "localhost"
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host ::1 serv tftp
+ai1: flags 0x2 family 24 socktype 2 protocol 17 addrlen 28 host ::1 serv 69
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host 127.0.0.1 serv tftp
+ai1: flags 0x2 family 2 socktype 2 protocol 17 addrlen 16 host 127.0.0.1 serv 69
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host localhost serv tftp
+ai1: flags 0x2 family 24 socktype 2 protocol 17 addrlen 28 host ::1 serv 69 cname "localhost"
+ai2: flags 0x2 family 2 socktype 2 protocol 17 addrlen 16 host 127.0.0.1 serv 69 cname "localhost"
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host ::1 serv echo
+ai1: flags 0x2 family 24 socktype 2 protocol 17 addrlen 28 host ::1 serv echo
+ai2: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv echo
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host 127.0.0.1 serv echo
+ai1: flags 0x2 family 2 socktype 2 protocol 17 addrlen 16 host 127.0.0.1 serv echo
+ai2: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv echo
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host localhost serv echo
+ai1: flags 0x2 family 24 socktype 2 protocol 17 addrlen 28 host ::1 serv echo cname "localhost"
+ai2: flags 0x2 family 2 socktype 2 protocol 17 addrlen 16 host 127.0.0.1 serv echo cname "localhost"
+ai3: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv echo cname "localhost"
+ai4: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv echo cname "localhost"
+
+== specific address family
+arg: flags 0x2 family 2 socktype 0 protocol 0 addrlen 0 host localhost serv http
+ai1: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv www cname "localhost"
+arg: flags 0x2 family 24 socktype 0 protocol 0 addrlen 0 host localhost serv http
+ai1: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv www cname "localhost"
+
+== empty hostname
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host (empty) serv http
+ai1: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv www
+ai2: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv www
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host (empty) serv echo
+ai1: flags 0x2 family 24 socktype 2 protocol 17 addrlen 28 host ::1 serv echo
+ai2: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv echo
+ai3: flags 0x2 family 2 socktype 2 protocol 17 addrlen 16 host 127.0.0.1 serv echo
+ai4: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv echo
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host (empty) serv tftp
+ai1: flags 0x2 family 24 socktype 2 protocol 17 addrlen 28 host ::1 serv 69
+ai2: flags 0x2 family 2 socktype 2 protocol 17 addrlen 16 host 127.0.0.1 serv 69
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host (empty) serv 80
+servname not supported for ai_socktype
+arg: flags 0x3 family 0 socktype 0 protocol 0 addrlen 0 host (empty) serv http
+ai1: flags 0x3 family 24 socktype 1 protocol 6 addrlen 28 host :: serv www
+ai2: flags 0x3 family 2 socktype 1 protocol 6 addrlen 16 host 0.0.0.0 serv www
+arg: flags 0x3 family 0 socktype 0 protocol 0 addrlen 0 host (empty) serv echo
+ai1: flags 0x3 family 24 socktype 2 protocol 17 addrlen 28 host :: serv echo
+ai2: flags 0x3 family 24 socktype 1 protocol 6 addrlen 28 host :: serv echo
+ai3: flags 0x3 family 2 socktype 2 protocol 17 addrlen 16 host 0.0.0.0 serv echo
+ai4: flags 0x3 family 2 socktype 1 protocol 6 addrlen 16 host 0.0.0.0 serv echo
+arg: flags 0x3 family 0 socktype 0 protocol 0 addrlen 0 host (empty) serv tftp
+ai1: flags 0x3 family 24 socktype 2 protocol 17 addrlen 28 host :: serv 69
+ai2: flags 0x3 family 2 socktype 2 protocol 17 addrlen 16 host 0.0.0.0 serv 69
+arg: flags 0x3 family 0 socktype 0 protocol 0 addrlen 0 host (empty) serv 80
+servname not supported for ai_socktype
+arg: flags 0x2 family 0 socktype 1 protocol 0 addrlen 0 host (empty) serv 80
+ai1: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv www
+ai2: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv www
+arg: flags 0x2 family 0 socktype 2 protocol 0 addrlen 0 host (empty) serv 80
+ai1: flags 0x2 family 24 socktype 2 protocol 17 addrlen 28 host ::1 serv www
+ai2: flags 0x2 family 2 socktype 2 protocol 17 addrlen 16 host 127.0.0.1 serv www
+
+== empty servname
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host ::1 serv (empty)
+ai1: flags 0x2 family 24 socktype 2 protocol 17 addrlen 28 host ::1 serv 0
+ai2: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv 0
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host 127.0.0.1 serv (empty)
+ai1: flags 0x2 family 2 socktype 2 protocol 17 addrlen 16 host 127.0.0.1 serv 0
+ai2: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv 0
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host localhost serv (empty)
+ai1: flags 0x2 family 24 socktype 2 protocol 17 addrlen 28 host ::1 serv 0 cname "localhost"
+ai2: flags 0x2 family 2 socktype 2 protocol 17 addrlen 16 host 127.0.0.1 serv 0 cname "localhost"
+ai3: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host ::1 serv 0 cname "localhost"
+ai4: flags 0x2 family 2 socktype 1 protocol 6 addrlen 16 host 127.0.0.1 serv 0 cname "localhost"
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host (empty) serv (empty)
+hostname nor servname provided, or not known
+
+== sock_raw
+arg: flags 0x2 family 0 socktype 3 protocol 0 addrlen 0 host localhost serv (empty)
+ai1: flags 0x2 family 24 socktype 3 protocol 0 addrlen 28 host ::1 serv 0 cname "localhost"
+ai2: flags 0x2 family 2 socktype 3 protocol 0 addrlen 16 host 127.0.0.1 serv 0 cname "localhost"
+arg: flags 0x2 family 0 socktype 3 protocol 59 addrlen 0 host localhost serv (empty)
+ai1: flags 0x2 family 24 socktype 3 protocol 59 addrlen 28 host ::1 serv 0 cname "localhost"
+ai2: flags 0x2 family 2 socktype 3 protocol 59 addrlen 16 host 127.0.0.1 serv 0 cname "localhost"
+arg: flags 0x2 family 0 socktype 3 protocol 59 addrlen 0 host localhost serv 80
+servname not supported for ai_socktype
+arg: flags 0x2 family 0 socktype 3 protocol 59 addrlen 0 host localhost serv www
+servname not supported for ai_socktype
+arg: flags 0x2 family 0 socktype 3 protocol 59 addrlen 0 host ::1 serv (empty)
+ai1: flags 0x2 family 24 socktype 3 protocol 59 addrlen 28 host ::1 serv 0
+
+== unsupported family
+arg: flags 0x2 family 99 socktype 0 protocol 0 addrlen 0 host localhost serv (empty)
+ai_family not supported
+
+== the following items are specified in jinmei scopeaddr format doc.
+arg: flags 0x2 family 0 socktype 0 protocol 0 addrlen 0 host fe80::1%lo0 serv http
+ai1: flags 0x2 family 24 socktype 1 protocol 6 addrlen 28 host fe80::1%lo0 serv www
+
diff -r 13b6b4513bb2 -r b7afaf86bbb0 regress/lib/libc/getaddrinfo/gaitest.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/regress/lib/libc/getaddrinfo/gaitest.c    Fri Jul 05 15:42:41 2002 +0000
@@ -0,0 +1,149 @@
+#include <sys/types.h>
+#include <sys/socket.h>
+#include <netinet/in.h>
+#include <arpa/inet.h>
+#include <netdb.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <unistd.h>
+
+struct addrinfo ai;
+
+char host[NI_MAXHOST];
+char serv[NI_MAXSERV];
+int vflag = 0;
+
+static void
+usage()
+{
+       fprintf(stderr, "usage: test [-f family] [-s socktype] [-p proto] [-DPRSv46] host serv\n");
+}
+
+static void
+print1(title, res, h, s)
+       const char *title;
+       const struct addrinfo *res;
+       char *h;
+       char *s;
+{
+       char *start, *end;
+       int error;
+       const int niflag = NI_NUMERICHOST;
+
+       if (res->ai_addr) {
+               error = getnameinfo(res->ai_addr, res->ai_addr->sa_len,
+                                   host, sizeof(host), serv, sizeof(serv),
+                                   niflag);
+               h = host;
+               s = serv;
+       } else
+               error = 0;
+
+       if (vflag) {
+               start = "\t";
+               end = "\n";
+       } else {
+               start = " ";
+               end = "";
+       }
+       printf("%s%s", title, end);
+       printf("%sflags 0x%x%s", start, res->ai_flags, end);
+       printf("%sfamily %d%s", start, res->ai_family, end);
+       printf("%ssocktype %d%s", start, res->ai_socktype, end);
+       printf("%sprotocol %d%s", start, res->ai_protocol, end);
+       printf("%saddrlen %d%s", start, res->ai_addrlen, end);
+       if (error)
+               printf("%serror %d%s", start, error, end);
+       else {
+               printf("%shost %s%s", start, h, end);
+               printf("%sserv %s%s", start, s, end);
+       }
+       if (res->ai_canonname)
+               printf("%scname \"%s\"%s", start, res->ai_canonname, end);
+       if (!vflag)
+               printf("\n");
+
+}
+
+int
+main(argc, argv)
+       int argc;
+       char *argv[];
+{
+       struct addrinfo *res;
+       int error, i;
+       char *p, *q;
+       extern int optind;
+       extern char *optarg;
+       int c;
+       char nbuf[10];
+
+       memset(&ai, 0, sizeof(ai));
+       ai.ai_family = PF_UNSPEC;
+       ai.ai_flags |= AI_CANONNAME;
+       while ((c = getopt(argc, argv, "Df:p:PRs:Sv46")) != -1) {
+               switch (c) {
+               case 'D':
+                       ai.ai_socktype = SOCK_DGRAM;
+                       break;
+               case 'f':
+                       ai.ai_family = atoi(optarg);
+                       break;
+               case 'p':
+                       ai.ai_protocol = atoi(optarg);
+                       break;
+               case 'P':
+                       ai.ai_flags |= AI_PASSIVE;
+                       break;
+               case 'R':
+                       ai.ai_socktype = SOCK_RAW;
+                       break;
+               case 's':
+                       ai.ai_socktype = atoi(optarg);
+                       break;
+               case 'S':
+                       ai.ai_socktype = SOCK_STREAM;
+                       break;
+               case 'v':
+                       vflag++;
+                       break;
+               case '4':
+                       ai.ai_family = PF_INET;
+                       break;
+               case '6':
+                       ai.ai_family = PF_INET6;
+                       break;
+               default:
+                       usage();
+                       exit(1);
+               }
+       }
+       argc -= optind;
+       argv += optind;
+
+       if (argc != 2){
+               usage();
+               exit(1);
+       }
+
+       p = *argv[0] ? argv[0] : NULL;
+       q = *argv[1] ? argv[1] : NULL;
+
+       print1("arg:", &ai, p ? p : "(empty)", q ? q : "(empty)");
+
+       error = getaddrinfo(p, q, &ai, &res);
+       if (error) {
+               printf("%s\n", gai_strerror(error));
+               exit(1);
+       }
+
+       i = 1;
+       do {
+               snprintf(nbuf, sizeof(nbuf), "ai%d:", i);
+               print1(nbuf, res, NULL, NULL);
+
+               i++;
+       } while ((res = res->ai_next) != NULL);
+
+       exit(0);
+}
diff -r 13b6b4513bb2 -r b7afaf86bbb0 regress/lib/libc/getaddrinfo/testsuite.sh
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/regress/lib/libc/getaddrinfo/testsuite.sh Fri Jul 05 15:42:41 2002 +0000
@@ -0,0 +1,58 @@



Home | Main Index | Thread Index | Old Index