From 8a2cd84c047ef7500dc8149ed6ace8e9fa631cad Mon Sep 17 00:00:00 2001 From: Greg Hudson Date: Thu, 28 May 2020 18:41:02 -0400 Subject: [PATCH] Remove resolver test utility tests/resolve is no longer used after the previous commit. [rharwood@redhat.com: .gitignore] --- src/configure.ac | 5 +- src/tests/Makefile.in | 4 +- src/tests/resolve/Makefile.in | 28 --- src/tests/resolve/addrinfo-test.c | 306 ------------------------- src/tests/resolve/deps | 14 -- src/tests/resolve/fake-addrinfo-test.c | 3 - src/tests/resolve/resolve.c | 115 ---------- 7 files changed, 4 insertions(+), 471 deletions(-) delete mode 100644 src/tests/resolve/Makefile.in delete mode 100644 src/tests/resolve/addrinfo-test.c delete mode 100644 src/tests/resolve/deps delete mode 100644 src/tests/resolve/fake-addrinfo-test.c delete mode 100644 src/tests/resolve/resolve.c diff --git a/src/configure.ac b/src/configure.ac index aafc462f9..00b5ea4c5 100644 --- a/src/configure.ac +++ b/src/configure.ac @@ -1540,7 +1540,6 @@ V5_AC_OUTPUT_MAKEFILE(. appl/simple appl/simple/client appl/simple/server appl/gss-sample appl/user_user - tests tests/resolve tests/asn.1 tests/create tests/hammer - tests/verify tests/gssapi tests/dejagnu tests/threads tests/shlib - tests/gss-threads tests/misc + tests tests/asn.1 tests/create tests/hammer tests/verify tests/gssapi + tests/dejagnu tests/threads tests/shlib tests/gss-threads tests/misc ) diff --git a/src/tests/Makefile.in b/src/tests/Makefile.in index 3f88f1713..6b7749129 100644 --- a/src/tests/Makefile.in +++ b/src/tests/Makefile.in @@ -1,7 +1,7 @@ mydir=tests BUILDTOP=$(REL).. -SUBDIRS = resolve asn.1 create hammer verify gssapi dejagnu shlib \ - gss-threads misc threads softpkcs11 +SUBDIRS = asn.1 create hammer verify gssapi dejagnu shlib gss-threads misc \ + threads softpkcs11 RUN_DB_TEST = $(RUN_SETUP) KRB5_KDC_PROFILE=kdc.conf KRB5_CONFIG=krb5.conf \ GSS_MECH_CONFIG=mech.conf LC_ALL=C $(VALGRIND) diff --git a/src/tests/resolve/Makefile.in b/src/tests/resolve/Makefile.in deleted file mode 100644 index 1f5954089..000000000 --- a/src/tests/resolve/Makefile.in +++ /dev/null @@ -1,28 +0,0 @@ -mydir=tests$(S)resolve -BUILDTOP=$(REL)..$(S).. - -OBJS=resolve.o addrinfo-test.o fake-addrinfo-test.o -SRCS=$(srcdir)/resolve.c $(srcdir)/addrinfo-test.c \ - $(srcdir)/fake-addrinfo-test.c - -all: resolve addrinfo-test fake-addrinfo-test - -resolve: resolve.o - $(CC_LINK) -o $@ resolve.o $(SUPPORT_LIB) $(LIBS) - -addrinfo-test: addrinfo-test.o - $(CC_LINK) -o $@ addrinfo-test.o $(SUPPORT_LIB) $(LIBS) - -fake-addrinfo-test: fake-addrinfo-test.o - $(CC_LINK) -o $@ fake-addrinfo-test.o $(SUPPORT_LIB) $(LIBS) - -check: resolve addrinfo-test fake-addrinfo-test - $(RUN_TEST) ./resolve - $(RUN_TEST) ./addrinfo-test -p telnet - $(RUN_TEST) ./fake-addrinfo-test -p telnet - -install: - -clean: - $(RM) resolve addrinfo-test fake-addrinfo-test - diff --git a/src/tests/resolve/addrinfo-test.c b/src/tests/resolve/addrinfo-test.c deleted file mode 100644 index e77640b62..000000000 --- a/src/tests/resolve/addrinfo-test.c +++ /dev/null @@ -1,306 +0,0 @@ -/* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil -*- */ -/* tests/resolve/addrinfo-test.c */ -/* - * Copyright 2004 by the Massachusetts Institute of Technology. - * All Rights Reserved. - * - * Export of this software from the United States of America may - * require a specific license from the United States Government. - * It is the responsibility of any person or organization contemplating - * export to obtain such a license before exporting. - * - * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and - * distribute this software and its documentation for any purpose and - * without fee is hereby granted, provided that the above copyright - * notice appear in all copies and that both that copyright notice and - * this permission notice appear in supporting documentation, and that - * the name of M.I.T. not be used in advertising or publicity pertaining - * to distribution of the software without specific, written prior - * permission. Furthermore if you modify this software you must label - * your software as modified software and not distribute it in such a - * fashion that it might be confused with the original M.I.T. software. - * M.I.T. makes no representations about the suitability of - * this software for any purpose. It is provided "as is" without express - * or implied warranty. - */ - -/* - * A simple program to test the functionality of the getaddrinfo function. - * - * Usage: - * addrinfo-test [-t|-u|-R|-I] [-d|-s|-r] [-p port] [-P] [hostname] - * - * When invoked with no arguments, NULL is used for the node name, - * which (at least with a non-null "port") means a socket address - * is desired that can be used with connect() or bind() (depending - * on whether "-P" is given). - */ - -#include -#include -#include -#include -#include /* needed for IPPROTO_* on NetBSD */ -#ifdef USE_FAKE_ADDRINFO -#include "fake-addrinfo.h" -#endif - -static const char *protoname (int p) { - static char buf[30]; - -#define X(N) if (p == IPPROTO_ ## N) return #N - - X(TCP); - X(UDP); - X(ICMP); -#ifdef IPPROTO_IPV6 - X(IPV6); -#endif -#ifdef IPPROTO_GRE - X(GRE); -#endif -#ifdef IPPROTO_NONE - X(NONE); -#endif - X(RAW); -#ifdef IPPROTO_COMP - X(COMP); -#endif - - snprintf(buf, sizeof(buf), " %-2d", p); - return buf; -} - -static const char *socktypename (int t) { - static char buf[30]; - switch (t) { - case SOCK_DGRAM: return "DGRAM"; - case SOCK_STREAM: return "STREAM"; - case SOCK_RAW: return "RAW"; - case SOCK_RDM: return "RDM"; - case SOCK_SEQPACKET: return "SEQPACKET"; - } - snprintf(buf, sizeof(buf), " %-2d", t); - return buf; -} - -static char *whoami; - -static void usage () { - fprintf(stderr, - "usage:\n" - "\t%s [ options ] [host]\n" - "options:\n" - "\t-t\tspecify protocol IPPROTO_TCP\n" - "\t-u\tspecify protocol IPPROTO_UDP\n" - "\t-R\tspecify protocol IPPROTO_RAW\n" - "\t-I\tspecify protocol IPPROTO_ICMP\n" - "\n" - "\t-d\tspecify socket type SOCK_DGRAM\n" - "\t-s\tspecify socket type SOCK_STREAM\n" - "\t-r\tspecify socket type SOCK_RAW\n" - "\n" - "\t-4\tspecify address family AF_INET\n" -#ifdef AF_INET6 - "\t-6\tspecify address family AF_INET6\n" -#endif - "\n" - "\t-p P\tspecify port P (service name or port number)\n" - "\t-N\thostname is numeric, skip DNS query\n" - "\t-n\tservice/port is numeric (sets AI_NUMERICSERV)\n" - "\t-P\tset AI_PASSIVE\n" - "\n" - "default: protocol 0, socket type 0, address family 0, null port\n" - , - whoami); - /* [ -t | -u | -R | -I ] [ -d | -s | -r ] [ -p port ] */ - exit (1); -} - -static const char *familyname (int f) { - static char buf[30]; - switch (f) { - default: - snprintf(buf, sizeof(buf), "AF %d", f); - return buf; - case AF_INET: return "AF_INET"; -#ifdef AF_INET6 - case AF_INET6: return "AF_INET6"; -#endif - } -} - -#define eaistr(X) (X == EAI_SYSTEM ? strerror(errno) : gai_strerror(X)) - -int main (int argc, char *argv[]) -{ - struct addrinfo *ap, *ap2; - int err, numerichost = 0, numericserv = 0; - char *hname, *port = 0, *sep; - struct addrinfo hints; - - whoami = strrchr(argv[0], '/'); - if (whoami == 0) - whoami = argv[0]; - else - whoami = whoami+1; - - memset(&hints, 0, sizeof(hints)); - hints.ai_flags = 0; - hints.ai_socktype = 0; - - hname = 0; - hints.ai_family = 0; - - if (argc == 1) - usage (); - - while (++argv, --argc > 0) { - char *arg; - arg = *argv; - - if (*arg != '-') - hname = arg; - else if (arg[1] == 0 || arg[2] != 0) - usage (); - else - switch (arg[1]) { - case 'u': - hints.ai_protocol = IPPROTO_UDP; - break; - case 't': - hints.ai_protocol = IPPROTO_TCP; - break; - case 'R': - hints.ai_protocol = IPPROTO_RAW; - break; - case 'I': - hints.ai_protocol = IPPROTO_ICMP; - break; - case 'd': - hints.ai_socktype = SOCK_DGRAM; - break; - case 's': - hints.ai_socktype = SOCK_STREAM; - break; - case 'r': - hints.ai_socktype = SOCK_RAW; - break; - case 'p': - if (argv[1] == 0 || argv[1][0] == 0 || argv[1][0] == '-') - usage (); - port = argv[1]; - argc--, argv++; - break; - case '4': - hints.ai_family = AF_INET; - break; -#ifdef AF_INET6 - case '6': - hints.ai_family = AF_INET6; - break; -#endif - case 'N': - numerichost = 1; - break; - case 'n': - numericserv = 1; - break; - case 'P': - hints.ai_flags |= AI_PASSIVE; - break; - default: - usage (); - } - } - - if (hname && !numerichost) - hints.ai_flags |= AI_CANONNAME; - if (numerichost) { -#ifdef AI_NUMERICHOST - hints.ai_flags |= AI_NUMERICHOST; -#else - fprintf(stderr, "AI_NUMERICHOST not defined on this platform\n"); - exit(1); -#endif - } - if (numericserv) { -#ifdef AI_NUMERICSERV - hints.ai_flags |= AI_NUMERICSERV; -#else - fprintf(stderr, "AI_NUMERICSERV not defined on this platform\n"); - exit(1); -#endif - } - - printf("getaddrinfo(hostname %s, service %s,\n" - " hints { ", - hname ? hname : "(null)", port ? port : "(null)"); - sep = ""; -#define Z(FLAG) if (hints.ai_flags & AI_##FLAG) printf("%s%s", sep, #FLAG), sep = "|" - Z(CANONNAME); - Z(PASSIVE); -#ifdef AI_NUMERICHOST - Z(NUMERICHOST); -#endif -#ifdef AI_NUMERICSERV - Z(NUMERICSERV); -#endif - if (sep[0] == 0) - printf ("no-flags"); - if (hints.ai_family) - printf(" %s", familyname(hints.ai_family)); - if (hints.ai_socktype) - printf(" SOCK_%s", socktypename(hints.ai_socktype)); - if (hints.ai_protocol) - printf(" IPPROTO_%s", protoname(hints.ai_protocol)); - printf(" }):\n"); - - err = getaddrinfo(hname, port, &hints, &ap); - if (err) { - printf("\terror => %s\n", eaistr(err)); - return 1; - } - - for (ap2 = ap; ap2; ap2 = ap2->ai_next) { - char hbuf[NI_MAXHOST], pbuf[NI_MAXSERV]; - /* If we don't do this, even AIX's own getnameinfo will reject - the sockaddr structures. The sa_len field doesn't get set - either, on AIX, but getnameinfo won't complain. */ - if (ap2->ai_addr->sa_family == 0) { - printf("BAD: sa_family zero! fixing...\n"); - ap2->ai_addr->sa_family = ap2->ai_family; - } else if (ap2->ai_addr->sa_family != ap2->ai_family) { - printf("BAD: sa_family != ai_family! fixing...\n"); - ap2->ai_addr->sa_family = ap2->ai_family; - } - if (getnameinfo(ap2->ai_addr, ap2->ai_addrlen, hbuf, sizeof(hbuf), - pbuf, sizeof(pbuf), NI_NUMERICHOST | NI_NUMERICSERV)) { - strlcpy(hbuf, "...", sizeof(hbuf)); - strlcpy(pbuf, "...", sizeof(pbuf)); - } - printf("%p:\n" - "\tfamily = %s\tproto = %-4s\tsocktype = %s\n", - (void *) ap2, familyname(ap2->ai_family), - protoname (ap2->ai_protocol), - socktypename (ap2->ai_socktype)); - if (ap2->ai_canonname) { - if (ap2->ai_canonname[0]) - printf("\tcanonname = %s\n", ap2->ai_canonname); - else - printf("BAD: ai_canonname is set but empty!\n"); - } else if (ap2 == ap && (hints.ai_flags & AI_CANONNAME)) { - printf("BAD: first ai_canonname is null!\n"); - } - printf("\taddr = %-28s\tport = %s\n", hbuf, pbuf); - - err = getnameinfo(ap2->ai_addr, ap2->ai_addrlen, hbuf, sizeof (hbuf), - pbuf, sizeof(pbuf), NI_NAMEREQD); - if (err) - printf("\tgetnameinfo(NI_NAMEREQD): %s\n", eaistr(err)); - else - printf("\tgetnameinfo => %s, %s\n", hbuf, pbuf); - } - freeaddrinfo(ap); - return 0; -} diff --git a/src/tests/resolve/deps b/src/tests/resolve/deps deleted file mode 100644 index 762d9adab..000000000 --- a/src/tests/resolve/deps +++ /dev/null @@ -1,14 +0,0 @@ -# -# Generated makefile dependencies follow. -# -$(OUTPRE)resolve.$(OBJEXT): $(BUILDTOP)/include/autoconf.h \ - $(top_srcdir)/include/k5-platform.h $(top_srcdir)/include/k5-thread.h \ - resolve.c -$(OUTPRE)addrinfo-test.$(OBJEXT): $(BUILDTOP)/include/autoconf.h \ - $(top_srcdir)/include/k5-platform.h $(top_srcdir)/include/k5-thread.h \ - addrinfo-test.c -$(OUTPRE)fake-addrinfo-test.$(OBJEXT): $(BUILDTOP)/include/autoconf.h \ - $(top_srcdir)/include/fake-addrinfo.h $(top_srcdir)/include/k5-platform.h \ - $(top_srcdir)/include/k5-thread.h $(top_srcdir)/include/port-sockets.h \ - $(top_srcdir)/include/socket-utils.h addrinfo-test.c \ - fake-addrinfo-test.c diff --git a/src/tests/resolve/fake-addrinfo-test.c b/src/tests/resolve/fake-addrinfo-test.c deleted file mode 100644 index 86365a5ba..000000000 --- a/src/tests/resolve/fake-addrinfo-test.c +++ /dev/null @@ -1,3 +0,0 @@ -/* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil -*- */ -#define USE_FAKE_ADDRINFO -#include "addrinfo-test.c" diff --git a/src/tests/resolve/resolve.c b/src/tests/resolve/resolve.c deleted file mode 100644 index ea0239113..000000000 --- a/src/tests/resolve/resolve.c +++ /dev/null @@ -1,115 +0,0 @@ -/* -*- mode: c; c-basic-offset: 4; indent-tabs-mode: nil -*- */ -/* tests/resolve/resolve.c */ -/* - * Copyright 1995 by the Massachusetts Institute of Technology. - * All Rights Reserved. - * - * Export of this software from the United States of America may - * require a specific license from the United States Government. - * It is the responsibility of any person or organization contemplating - * export to obtain such a license before exporting. - * - * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and - * distribute this software and its documentation for any purpose and - * without fee is hereby granted, provided that the above copyright - * notice appear in all copies and that both that copyright notice and - * this permission notice appear in supporting documentation, and that - * the name of M.I.T. not be used in advertising or publicity pertaining - * to distribution of the software without specific, written prior - * permission. Furthermore if you modify this software you must label - * your software as modified software and not distribute it in such a - * fashion that it might be confused with the original M.I.T. software. - * M.I.T. makes no representations about the suitability of - * this software for any purpose. It is provided "as is" without express - * or implied warranty. - */ - -/* - * A simple program to test the functionality of the resolver library. - * It simply will try to get the IP address of the host, and then look - * up the name from the address. If the resulting name does not contain the - * domain name, then the resolve library is broken. - * - * Warning: It is possible to fool this program into thinking everything is - * alright by a clever use of /etc/hosts - but this is better than nothing. - * - * Usage: - * resolve [hostname] - * - * When invoked with no arguments, gethostname is used for the local host. - * - */ - -/* This program tests the resolve library and sees if it is broken... */ - -#include "k5-platform.h" -#include -#include -#include -#include -#ifdef HAVE_SYS_PARAM_H -#include -#endif - -int -main(int argc, char **argv) -{ - struct addrinfo *ai = NULL, hint; - char myname[MAXHOSTNAMELEN + 1], namebuf[NI_MAXHOST], abuf[256]; - const char *addrstr; - int err, quiet = 0; - - argc--; argv++; - while (argc) { - if ((strcmp(*argv, "--quiet") == 0) || - (strcmp(*argv, "-q") == 0)) { - quiet++; - } else - break; - argc--; argv++; - } - - if (argc >= 1) { - strlcpy(myname, *argv, sizeof(myname)); - } else { - if(gethostname(myname, MAXHOSTNAMELEN)) { - perror("gethostname failure"); - exit(1); - } - } - - myname[MAXHOSTNAMELEN] = '\0'; /* for safety */ - - /* Look up the address... */ - if (!quiet) - printf("Hostname: %s\n", myname); - - memset(&hint, 0, sizeof(hint)); - hint.ai_flags = AI_CANONNAME; - err = getaddrinfo(myname, 0, &hint, &ai); - if (err) { - fprintf(stderr, - "Could not look up address for hostname '%s' - fatal\n", - myname); - exit(2); - } - - if (!quiet) { - addrstr = inet_ntop(ai->ai_family, ai->ai_addr, abuf, sizeof(abuf)); - if (addrstr != NULL) - printf("Host address: %s\n", addrstr); - } - - err = getnameinfo(ai->ai_addr, ai->ai_addrlen, namebuf, sizeof(namebuf), - NULL, 0, NI_NAMEREQD); - if (err && !quiet) - fprintf(stderr, "Error looking up IP address\n"); - - printf("%s%s\n", quiet ? "" : "FQDN: ", err ? ai->ai_canonname : namebuf); - - if (!quiet) - printf("Resolve library appears to have passed the test\n"); - - freeaddrinfo(ai); - return 0; -}