diff options
author | Daniel Stenberg <daniel@haxx.se> | 2005-04-30 23:30:55 +0000 |
---|---|---|
committer | Daniel Stenberg <daniel@haxx.se> | 2005-04-30 23:30:55 +0000 |
commit | 23da55a9f14ff5c48f0bc297f1ff745eb3dc7554 (patch) | |
tree | 14a55b55be48c061aebd4f0b5cf85475bcf2b263 /tests | |
parent | 41e6292e7be530c0a273de4121c48169996cb547 (diff) |
Moved common code to util.[ch] instead of having it duplicated in sws.c
and sockfilt.c. For good-to-have functions for the servers written in C.
Diffstat (limited to 'tests')
-rw-r--r-- | tests/server/Makefile.am | 6 | ||||
-rw-r--r-- | tests/server/sockfilt.c | 44 | ||||
-rw-r--r-- | tests/server/sws.c | 27 | ||||
-rw-r--r-- | tests/server/util.c | 95 | ||||
-rw-r--r-- | tests/server/util.h | 30 |
5 files changed, 136 insertions, 66 deletions
diff --git a/tests/server/Makefile.am b/tests/server/Makefile.am index 4444ed5b4..ab36e2798 100644 --- a/tests/server/Makefile.am +++ b/tests/server/Makefile.am @@ -29,10 +29,10 @@ noinst_PROGRAMS = sws getpart sockfilt useful = getpart.c getpart.h $(top_srcdir)/lib/strequal.c \ $(top_srcdir)/lib/base64.c $(top_srcdir)/lib/mprintf.c \ - $(top_srcdir)/lib/memdebug.c + $(top_srcdir)/lib/memdebug.c $(top_srcdir)/lib/timeval.c -sws_SOURCES= sws.c $(useful) -sockfilt_SOURCES = sockfilt.c $(useful) $(top_srcdir)/lib/inet_pton.c +sws_SOURCES= sws.c util.c $(useful) +sockfilt_SOURCES = sockfilt.c util.c $(useful) $(top_srcdir)/lib/inet_pton.c getpart_SOURCES= testpart.c $(useful) extra_DIST = base64.pl diff --git a/tests/server/sockfilt.c b/tests/server/sockfilt.c index cf6cc499f..e177c676e 100644 --- a/tests/server/sockfilt.c +++ b/tests/server/sockfilt.c @@ -23,7 +23,8 @@ /* Purpose * - * 1. Accept a TCP connection on a custom port (ipv4 or ipv6). + * 1. Accept a TCP connection on a custom port (ipv4 or ipv6), or connect + * to a given (localhost) port. * * 2. Get commands on STDIN. Pass data on to the TCP stream. * Get data from TCP stream and pass on to STDOUT. @@ -77,6 +78,7 @@ #include "curlx.h" /* from the private lib dir */ #include "getpart.h" #include "inet_pton.h" +#include "util.h" #ifndef FALSE #define FALSE 0 @@ -118,43 +120,7 @@ const struct in6_addr in6addr_any = {{ IN6ADDR_ANY_INIT }}; static volatile int sigpipe; /* Why? It's not used */ #endif -char *socklogfile = (char *)DEFAULT_LOGFILE; - -/* - * ourerrno() returns the errno (or equivalent) on this platform to - * hide platform specific for the function that calls this. - */ -static int ourerrno(void) -{ -#ifdef WIN32 - return (int)GetLastError(); -#else - return errno; -#endif -} - -static void logmsg(const char *msg, ...) -{ - time_t t = time(NULL); - va_list ap; - struct tm *curr_time = localtime(&t); - char buffer[256]; /* possible overflow if you pass in a huge string */ - FILE *logfp; - - va_start(ap, msg); - vsprintf(buffer, msg, ap); - va_end(ap); - - logfp = fopen(socklogfile, "a"); - - fprintf(logfp?logfp:stderr, /* write to stderr if the logfile doesn't open */ - "%02d:%02d:%02d %s\n", - curr_time->tm_hour, - curr_time->tm_min, - curr_time->tm_sec, buffer); - if(logfp) - fclose(logfp); -} +const char *serverlogfile = (char *)DEFAULT_LOGFILE; static void lograw(unsigned char *buffer, int len) { @@ -492,7 +458,7 @@ int main(int argc, char *argv[]) else if(!strcmp("--logfile", argv[arg])) { arg++; if(argc>arg) - socklogfile = argv[arg++]; + serverlogfile = argv[arg++]; } else if(!strcmp("--ipv6", argv[arg])) { #ifdef ENABLE_IPV6 diff --git a/tests/server/sws.c b/tests/server/sws.c index 3000579f2..852b27a2e 100644 --- a/tests/server/sws.c +++ b/tests/server/sws.c @@ -57,6 +57,7 @@ #include "curlx.h" /* from the private lib dir */ #include "getpart.h" +#include "util.h" #ifdef ENABLE_IPV6 #define SWS_IPV6 @@ -124,6 +125,8 @@ void storerequest(char *reqbuf); #define DEFAULT_LOGFILE "log/sws.log" #endif +const char *serverlogfile = DEFAULT_LOGFILE; + #define SWSVERSION "cURL test suite HTTP server/0.1" #define REQUEST_DUMP "log/server.input" @@ -185,30 +188,6 @@ static const char *doc404 = "HTTP/1.1 404 Not Found\r\n" static volatile int sigpipe; /* Why? It's not used */ #endif -static void logmsg(const char *msg, ...) -{ - time_t t = time(NULL); - va_list ap; - struct tm *curr_time = localtime(&t); - char buffer[256]; /* possible overflow if you pass in a huge string */ - FILE *logfp; - - va_start(ap, msg); - vsprintf(buffer, msg, ap); - va_end(ap); - - logfp = fopen(DEFAULT_LOGFILE, "a"); - - fprintf(logfp?logfp:stderr, /* write to stderr if the logfile doesn't open */ - "%02d:%02d:%02d %s\n", - curr_time->tm_hour, - curr_time->tm_min, - curr_time->tm_sec, buffer); - if(logfp) - fclose(logfp); -} - - #ifdef SIGPIPE static void sigpipe_handler(int sig) { diff --git a/tests/server/util.c b/tests/server/util.c new file mode 100644 index 000000000..74d5dcdfe --- /dev/null +++ b/tests/server/util.c @@ -0,0 +1,95 @@ +/*************************************************************************** + * _ _ ____ _ + * Project ___| | | | _ \| | + * / __| | | | |_) | | + * | (__| |_| | _ <| |___ + * \___|\___/|_| \_\_____| + * + * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. + * + * This software is licensed as described in the file COPYING, which + * you should have received as part of this distribution. The terms + * are also available at http://curl.haxx.se/docs/copyright.html. + * + * You may opt to use, copy, modify, merge, publish, distribute and/or sell + * copies of the Software, and permit persons to whom the Software is + * furnished to do so, under the terms of the COPYING file. + * + * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY + * KIND, either express or implied. + * + * $Id$ + ***************************************************************************/ +#include "setup.h" /* portability help from the lib directory */ + +#include <stdio.h> +#include <stdlib.h> +#include <string.h> +#include <stdarg.h> +#include <signal.h> +#include <time.h> +#include <sys/time.h> +#include <sys/types.h> + +#ifdef HAVE_UNISTD_H +#include <unistd.h> +#endif +#ifdef HAVE_SYS_SOCKET_H +#include <sys/socket.h> +#endif +#ifdef HAVE_NETINET_IN_H +#include <netinet/in.h> +#endif +#ifdef _XOPEN_SOURCE_EXTENDED +/* This define is "almost" required to build on HPUX 11 */ +#include <arpa/inet.h> +#endif +#ifdef HAVE_NETDB_H +#include <netdb.h> +#endif + +#include "curlx.h" /* from the private lib dir */ +#include "getpart.h" +#include "util.h" + +/* + * ourerrno() returns the errno (or equivalent) on this platform to + * hide platform specific for the function that calls this. + */ +int ourerrno(void) +{ +#ifdef WIN32 + return (int)GetLastError(); +#else + return errno; +#endif +} + +/* someone else must set this properly */ +extern char *serverlogfile; + +void logmsg(const char *msg, ...) +{ + va_list ap; + char buffer[256]; /* possible overflow if you pass in a huge string */ + FILE *logfp; + + struct timeval tv = curlx_tvnow(); + struct tm *now = + localtime(&tv.tv_sec); /* not multithread safe but we don't care */ + + char timebuf[12]; + snprintf(timebuf, sizeof(timebuf), "%02d:%02d:%02d.%02ld", + now->tm_hour, now->tm_min, now->tm_sec, + tv.tv_usec/10000); + + va_start(ap, msg); + vsprintf(buffer, msg, ap); + va_end(ap); + + logfp = fopen(serverlogfile, "a"); + fprintf(logfp?logfp:stderr, /* write to stderr if the logfile doesn't open */ + "%s %s\n", timebuf, buffer); + if(logfp) + fclose(logfp); +} diff --git a/tests/server/util.h b/tests/server/util.h new file mode 100644 index 000000000..a56c5c445 --- /dev/null +++ b/tests/server/util.h @@ -0,0 +1,30 @@ +#ifndef __SERVER_UTIL_H +#define __SERVER_UTIL_H +/*************************************************************************** + * _ _ ____ _ + * Project ___| | | | _ \| | + * / __| | | | |_) | | + * | (__| |_| | _ <| |___ + * \___|\___/|_| \_\_____| + * + * Copyright (C) 1998 - 2005, Daniel Stenberg, <daniel@haxx.se>, et al. + * + * This software is licensed as described in the file COPYING, which + * you should have received as part of this distribution. The terms + * are also available at http://curl.haxx.se/docs/copyright.html. + * + * You may opt to use, copy, modify, merge, publish, distribute and/or sell + * copies of the Software, and permit persons to whom the Software is + * furnished to do so, under the terms of the COPYING file. + * + * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY + * KIND, either express or implied. + * + * $Id$ + ***************************************************************************/ + +int ourerrno(void); +void logmsg(const char *msg, ...); + + +#endif |