Compare commits
	
		
			32 Commits
		
	
	
		
			curl-7_9_5
			...
			curl-7_9_5
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | d9c244278d | ||
|   | b6c4185b27 | ||
|   | 5896d35e72 | ||
|   | b4dfdd8bbc | ||
|   | e6ed3478ea | ||
|   | db08d9c6b9 | ||
|   | 9490278ece | ||
|   | fd8bf5f171 | ||
|   | c9bc14a222 | ||
|   | 63708cbfb0 | ||
|   | d9f307623c | ||
|   | 540f77a627 | ||
|   | 71bb2d0b8b | ||
|   | 87dc44e434 | ||
|   | 29e0fcd091 | ||
|   | 2e9a798f09 | ||
|   | b32a39f44f | ||
|   | d86f9611b3 | ||
|   | 6a62fc4a40 | ||
|   | 7cdd6455d7 | ||
|   | e4fefd088d | ||
|   | 95e601e2b1 | ||
|   | b1ffe7b74a | ||
|   | 417c8fb602 | ||
|   | 85efa64c31 | ||
|   | d8cb026e80 | ||
|   | 41dd5121f0 | ||
|   | 94482d7ca5 | ||
|   | 4d0e51aead | ||
|   | ae8a8c8ba4 | ||
|   | 7d043f46d5 | ||
|   | cbca19d6c2 | 
							
								
								
									
										37
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								CHANGES
									
									
									
									
									
								
							| @@ -7,6 +7,43 @@ | ||||
|                                History of Changes | ||||
|  | ||||
|  | ||||
| Daniel (25 February 2002) | ||||
| - Fiddled with the automake files to make all source files in the lib | ||||
|   directory not have ../src in the include path, and the src sources shouldn't | ||||
|   have ../lib! | ||||
|  | ||||
| - All 79 test cases ran OK under Linux and Solaris using the new HTTP server | ||||
|   in the test suite. The new HTTP server was first donated by Georg Horn and | ||||
|   subsequently modified to work with the test suite. It is currently still not | ||||
|   portable enough to run on "all over" but this is a start and I can run all | ||||
|   curl tests on my machines. This is an important requirement for the upcoming | ||||
|   public release. | ||||
|  | ||||
| - Using -d and -I on the same command line now reports an error, as it implies | ||||
|   two different HTTP requests that can't be mixed. | ||||
|  | ||||
| - Jeffrey Pohlmeyer provided a patch that made the -w/--write-out option | ||||
|   support %{content_type} to get the content type of the recent download. | ||||
|  | ||||
| - Kevin Roth reported that pre2 and pre3 didn't compile properly on cygwin, | ||||
|   and this was because I used #ifdef HAVE_WINSOCK_H in lib/multi.h to figure | ||||
|   out if we could include winsock.h which turns out not to be a wise choice to | ||||
|   do on cygwin since it has the file but can't include it! | ||||
|  | ||||
| Daniel (22 February 2002) | ||||
| - Added src/config-vms.h to the release archive. | ||||
|  | ||||
| - Fixed the connection timeout value again, the change from February 18 wasn't | ||||
|   complete. | ||||
|  | ||||
| Version 7.9.5-pre3 | ||||
|  | ||||
| Daniel (21 February 2002) | ||||
| - Kevin Roth and Andr<64>s Garc<72>a both found out that lib/config.h.in was missing | ||||
|   in the pre-release archive and thus the configure script failed. | ||||
|  | ||||
| Version 7.9.5-pre2 | ||||
|  | ||||
| Daniel (20 February 2002) | ||||
| - Andr<64>s Garc<72>a provided a solution to bug report #515228. the total time | ||||
|   counter was not set correctly when -I was used during some conditions (all | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| # $Id$ | ||||
| # | ||||
|  | ||||
| AUTOMAKE_OPTIONS = foreign no-dependencies | ||||
| AUTOMAKE_OPTIONS = foreign | ||||
|  | ||||
| EXTRA_DIST =						\ | ||||
| 	CHANGES LEGAL maketgz MITX.txt MPL-1.1.txt	\ | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| #                            | (__| |_| |  _ <| |___  | ||||
| #                             \___|\___/|_| \_\_____| | ||||
| # | ||||
| # Copyright (C) 2001, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # Copyright (C) 2002, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||
| # | ||||
| # In order to be useful for every potential user, curl and libcurl are | ||||
| # dual-licensed under the MPL and the MIT/X-derivate licenses. | ||||
|   | ||||
| @@ -8,7 +8,7 @@ AC_PREREQ(2.50) | ||||
| dnl First some basic init macros | ||||
| AC_INIT | ||||
| AC_CONFIG_SRCDIR([lib/urldata.h]) | ||||
| AM_CONFIG_HEADER(lib/config.h src/config.h) | ||||
| AM_CONFIG_HEADER(lib/config.h src/config.h tests/server/config.h) | ||||
|  | ||||
| dnl figure out the libcurl version | ||||
| VERSION=`sed -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curl.h` | ||||
| @@ -601,6 +601,7 @@ AC_CONFIG_FILES([Makefile \ | ||||
|            lib/Makefile \ | ||||
|            tests/Makefile \ | ||||
|            tests/data/Makefile \ | ||||
|            tests/server/Makefile \ | ||||
| 	   packages/Makefile \ | ||||
| 	   packages/Win32/Makefile \ | ||||
| 	   packages/Win32/cygwin/Makefile \ | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
| .\" nroff -man curl.1 | ||||
| .\" Written by Daniel Stenberg | ||||
| .\" | ||||
| .TH curl 1 "30 Nov 2001" "Curl 7.9.2" "Curl Manual" | ||||
| .TH curl 1 "25 Feb 2002" "Curl 7.9.5" "Curl Manual" | ||||
| .SH NAME | ||||
| curl \- transfer a URL | ||||
| .SH SYNOPSIS | ||||
| @@ -594,6 +594,9 @@ The average download speed that curl measured for the complete download. | ||||
| .TP | ||||
| .B speed_upload | ||||
| The average upload speed that curl measured for the complete upload. | ||||
| .TP | ||||
| .B content_type | ||||
| The Content-Type of the requested document, if there was any. (Added in 7.9.5) | ||||
| .RE | ||||
|  | ||||
| If this option is used several times, the last one will be used. | ||||
|   | ||||
| @@ -114,7 +114,7 @@ Global Preparation | ||||
|  call initialized. | ||||
|  | ||||
|  Repeated calls to curl_global_init() and curl_global_cleanup() should be | ||||
|  avoided. They should be called once each. | ||||
|  avoided. They should only be called once each. | ||||
|  | ||||
| Handle the Easy libcurl | ||||
|  | ||||
| @@ -741,6 +741,15 @@ Customizing Operations | ||||
|  consideration and you should be aware that you may violate the HTTP protocol | ||||
|  when doing so. | ||||
|  | ||||
|  There's only one aspect left in the HTTP requests that we haven't yet | ||||
|  mentioned how to modify: the version field. All HTTP requests includes the | ||||
|  version number to tell the server which version we support. libcurl speak | ||||
|  HTTP 1.1 by default. Some very old servers don't like getting 1.1-requests | ||||
|  and when dealing with stubborn old things like that, you can tell libcurl to | ||||
|  use 1.0 instead by doing something like this: | ||||
|  | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_HTTP_VERSION, CURLHTTP_VERSION_1_0); | ||||
|  | ||||
|  Not all protocols are HTTP-like, and thus the above may not help you when you | ||||
|  want to make for example your FTP transfers to behave differently. | ||||
|  | ||||
| @@ -770,16 +779,71 @@ Customizing Operations | ||||
|  instead be called CURLOPT_POSTQUOTE and used the exact same way. | ||||
|  | ||||
|  The custom FTP command will be issued to the server in the same order they | ||||
|  are built in the list, and if a command gets an error code returned back from | ||||
|  the server no more commands will be issued and libcurl will bail out with an | ||||
|  error code. Note that if you use CURLOPT_QUOTE to send commands before a | ||||
|  transfer, no transfer will actually take place then. | ||||
|  are added to the list, and if a command gets an error code returned back from | ||||
|  the server, no more commands will be issued and libcurl will bail out with an | ||||
|  error code (CURLE_FTP_QUOTE_ERROR). Note that if you use CURLOPT_QUOTE to | ||||
|  send commands before a transfer, no transfer will actually take place when a | ||||
|  quote command has failed. | ||||
|  | ||||
|  If you set the CURLOPT_HEADER to true, you will tell libcurl to get | ||||
|  information about the target file and output "headers" about it. The headers | ||||
|  will be in "HTTP-style", looking like they do in HTTP. | ||||
|  | ||||
|  The option to enable headers or to run custom FTP commands may be useful to | ||||
|  combine with CURLOPT_NOBODY. If this option is set, no actual file content | ||||
|  transfer will be performed. | ||||
|  | ||||
|  [ custom FTP commands without transfer, FTP "header-only", HTTP 1.0 ] | ||||
|  | ||||
| Cookies Without Chocolate Chips | ||||
|  | ||||
|  [ set cookies, read cookies from file, cookie-jar ] | ||||
|  In the HTTP sense, a cookie is a name with an associated value. A server | ||||
|  sends the name and value to the client, and expects it to get sent back on | ||||
|  every subsequent request to the server that matches the particular conditions | ||||
|  set. The conditions include that the domain name and path match and that the | ||||
|  cookie hasn't become too old. | ||||
|  | ||||
|  In real-world cases, servers send new cookies to replace existing one to | ||||
|  update them. Server use cookies to "track" users and to keep "sessions". | ||||
|  | ||||
|  Cookies are sent from server to clients with the header Set-Cookie: and | ||||
|  they're sent from clients to servers with the Cookie: header. | ||||
|  | ||||
|  To just send whatever cookie you want to a server, you can use CURLOPT_COOKIE | ||||
|  to set a cookie string like this: | ||||
|  | ||||
|     curl_easy_setopt(easyhandle, CURLOPT_COOKIE, "name1=var1; name2=var2;"); | ||||
|  | ||||
|  In many cases, that is not enough. You might want to dynamicly save whatever | ||||
|  cookies the remote server passes to you, and make sure those cookies are then | ||||
|  use accordingly on later requests. | ||||
|  | ||||
|  One way to do this, is to save all headers you receive in a plain file and | ||||
|  when you make a request, you tell libcurl to read the previous headers to | ||||
|  figure out which cookies to use. Set header file to read cookies from with | ||||
|  CURLOPT_COOKIEFILE. | ||||
|  | ||||
|  The CURLOPT_COOKIEFILE option also automaticly enables the cookie parser in | ||||
|  libcurl. Until the cookie parser is enabled, libcurl will not parse or | ||||
|  understand incoming cookies and they will just be ignored. However, when the | ||||
|  parser is enabled the cookies will be understood and the cookies will be kept | ||||
|  in memory and used properly in subsequent requests when the same handle is | ||||
|  used. Many times this is enough, and you may not have to save the cookies to | ||||
|  disk at all. Note that the file you specify to CURLOPT_COOKIEFILE doesn't | ||||
|  have to exist to enable the parser, so a common way to just enable the parser | ||||
|  and not read able might be to use a file name you know doesn't exist. | ||||
|  | ||||
|  If you rather use existing cookies that you've previously received with your | ||||
|  Netscape or Mozilla browsers, you can make libcurl use that cookie file as | ||||
|  input. The CURLOPT_COOKIEFILE is used for that too, as libcurl will | ||||
|  automaticly find out what kind of file it is and act accordingly. | ||||
|  | ||||
|  The perhaps most advanced cookie operation libcurl offers, is saving the | ||||
|  entire internal cookie state back into a Netscape/Mozilla formatted cookie | ||||
|  file. We call that the cookie-jar. When you set a file name with | ||||
|  CURLOPT_COOKIEJAR, that file name will be created and all received cookies | ||||
|  will be stored in it when curl_easy_cleanup() is called. This enabled cookies | ||||
|  to get passed on properly between multiple handles without any information | ||||
|  getting lost. | ||||
|  | ||||
|  | ||||
| Headers Equal Fun | ||||
|   | ||||
| @@ -613,8 +613,8 @@ CURLcode curl_global_init(long flags); | ||||
| void curl_global_cleanup(void); | ||||
|  | ||||
| /* This is the version number */ | ||||
| #define LIBCURL_VERSION "7.9.4" | ||||
| #define LIBCURL_VERSION_NUM 0x070904 | ||||
| #define LIBCURL_VERSION "7.9.5-pre4" | ||||
| #define LIBCURL_VERSION_NUM 0x070905 | ||||
|  | ||||
| /* linked-list structure for the CURLOPT_QUOTE option (and other) */ | ||||
| struct curl_slist { | ||||
|   | ||||
| @@ -2,18 +2,18 @@ | ||||
| # $Id$ | ||||
| # | ||||
|  | ||||
| AUTOMAKE_OPTIONS = foreign no-dependencies | ||||
| AUTOMAKE_OPTIONS = foreign nostdinc | ||||
|  | ||||
| EXTRA_DIST = getdate.y \ | ||||
|        Makefile.b32 Makefile.b32.resp Makefile.m32 Makefile.vc6 \ | ||||
|        libcurl.def dllinit.c curllib.dsp curllib.dsw \ | ||||
|        config-vms.h config-win32.h config-riscos.h config-mac.h | ||||
|        config-vms.h config-win32.h config-riscos.h config-mac.h \ | ||||
|        config.h.in | ||||
|  | ||||
| lib_LTLIBRARIES = libcurl.la | ||||
|  | ||||
| INCLUDES = -I$(top_srcdir)/include | ||||
|  | ||||
|  | ||||
| libcurl_la_LDFLAGS = -no-undefined -version-info 2:2:0 | ||||
| # This flag accepts an argument of the form current[:revision[:age]]. So, | ||||
| # passing -version-info 3:12:1 sets current to 3, revision to 12, and age to | ||||
|   | ||||
| @@ -364,8 +364,13 @@ CURLcode Curl_connecthost(struct connectdata *conn,  /* context */ | ||||
| #endif | ||||
|  | ||||
|     /* get the most strict timeout of the ones converted to milliseconds */ | ||||
|     if(data->set.timeout && | ||||
|        (data->set.timeout < data->set.connecttimeout)) | ||||
|     if(data->set.timeout && data->set.connecttimeout) { | ||||
|       if (data->set.timeout < data->set.connecttimeout) | ||||
|         timeout_ms = data->set.timeout*1000; | ||||
|       else  | ||||
|         timeout_ms = data->set.connecttimeout*1000; | ||||
|     } | ||||
|     else if(data->set.timeout) | ||||
|       timeout_ms = data->set.timeout*1000; | ||||
|     else | ||||
|       timeout_ms = data->set.connecttimeout*1000; | ||||
|   | ||||
| @@ -50,7 +50,7 @@ | ||||
| #ifdef HAVE_SYS_SOCKET_H | ||||
| #include <sys/socket.h> | ||||
| #endif | ||||
| #ifdef HAVE_WINSOCK_H | ||||
| #if defined(WIN32) && !defined(__GNUC__) || defined(__MINGW32__) | ||||
| #include <winsock.h> | ||||
| #endif | ||||
|  | ||||
|   | ||||
| @@ -2,26 +2,26 @@ | ||||
| # $Id$ | ||||
| # | ||||
|  | ||||
| # Some flags needed when trying to cause warnings ;-) | ||||
| # CFLAGS = -g -DMALLOCDEBUG # -Wall -pedantic | ||||
| #CPPFLAGS = -DGLOBURL -DCURL_SEPARATORS | ||||
| AUTOMAKE_OPTIONS = foreign nostdinc | ||||
|  | ||||
| INCLUDES = -I$(top_srcdir)/include | ||||
|  | ||||
| bin_PROGRAMS = curl #memtest | ||||
|  | ||||
| noinst_HEADERS = setup.h \ | ||||
| #memtest_SOURCES = memtest.c | ||||
| #memtest_LDADD = $(top_srcdir)/lib/libcurl.la | ||||
|  | ||||
| curl_SOURCES = main.c hugehelp.c urlglob.c writeout.c setup.h \ | ||||
| 	config-win32.h \ | ||||
| 	config-mac.h \ | ||||
| 	config-vms.h \ | ||||
| 	urlglob.h \ | ||||
| 	version.h \ | ||||
| 	writeout.h | ||||
| 	writeout.h \ | ||||
| 	config-win32.h \ | ||||
| 	config-mac.h \ | ||||
| 	config-vms.h	 | ||||
|  | ||||
| #memtest_SOURCES = memtest.c | ||||
| #memtest_LDADD = $(top_srcdir)/lib/libcurl.la | ||||
|  | ||||
| curl_SOURCES = main.c hugehelp.c urlglob.c writeout.c | ||||
| curl_LDADD = ../lib/libcurl.la | ||||
| curl_DEPENDENCIES = ../lib/libcurl.la | ||||
| BUILT_SOURCES = hugehelp.c | ||||
| @@ -35,8 +35,6 @@ EXTRA_DIST = mkhelp.pl curlmsg.msg \ | ||||
| 	macos/src/curl_GUSIConfig.cpp \ | ||||
| 	macos/src/macos_main.cpp | ||||
|  | ||||
| AUTOMAKE_OPTIONS = foreign no-dependencies | ||||
|  | ||||
| MANPAGE=$(top_srcdir)/docs/curl.1 | ||||
| README=$(top_srcdir)/docs/MANUAL | ||||
| MKHELP=$(top_srcdir)/src/mkhelp.pl | ||||
|   | ||||
| @@ -1176,8 +1176,8 @@ static ParameterError getparameter(char *flag, /* f or -long-flag */ | ||||
|           config->postfields=postdata; | ||||
|       } | ||||
|  | ||||
| /*      if(SetHTTPrequest(HTTPREQ_SIMPLEPOST, &config->httpreq)) | ||||
|         return PARAM_BAD_USE;*/ | ||||
|       if(SetHTTPrequest(HTTPREQ_SIMPLEPOST, &config->httpreq)) | ||||
|         return PARAM_BAD_USE; | ||||
|       break; | ||||
|     case 'D': | ||||
|       /* dump-header to given file name */ | ||||
|   | ||||
| @@ -1,3 +1,3 @@ | ||||
| #define CURL_NAME "curl" | ||||
| #define CURL_VERSION "7.9.5-pre1" | ||||
| #define CURL_VERSION "7.9.5-pre4" | ||||
| #define CURL_ID CURL_NAME " " CURL_VERSION " (" OS ") " | ||||
|   | ||||
| @@ -46,6 +46,7 @@ typedef enum { | ||||
|   VAR_HEADER_SIZE, | ||||
|   VAR_REQUEST_SIZE, | ||||
|   VAR_EFFECTIVE_URL, | ||||
|   VAR_CONTENT_TYPE, | ||||
|   VAR_NUM_OF_VARS /* must be the last */ | ||||
| } replaceid; | ||||
|  | ||||
| @@ -69,6 +70,7 @@ static struct variable replacements[]={ | ||||
|   {"size_upload", VAR_SIZE_UPLOAD}, | ||||
|   {"speed_download", VAR_SPEED_DOWNLOAD}, | ||||
|   {"speed_upload", VAR_SPEED_UPLOAD}, | ||||
|   {"content_type", VAR_CONTENT_TYPE}, | ||||
|   {NULL, 0} | ||||
| }; | ||||
|  | ||||
| @@ -165,6 +167,11 @@ void ourWriteOut(CURL *curl, char *writeinfo) | ||||
|                    curl_easy_getinfo(curl, CURLINFO_SPEED_UPLOAD, &doubleinfo)) | ||||
|                   fprintf(stream, "%.3f", doubleinfo); | ||||
|                 break; | ||||
|               case VAR_CONTENT_TYPE: | ||||
|                 if(CURLE_OK == | ||||
|                    curl_easy_getinfo(curl, CURLINFO_CONTENT_TYPE, &stringp)) | ||||
|                    fputs(stringp, stream); | ||||
|                break; | ||||
|               default: | ||||
|                 break; | ||||
|               } | ||||
|   | ||||
| @@ -62,8 +62,10 @@ One regex per line that is removed from the protocol dumps before the | ||||
| comparison is made. This is very useful to remove dependencies on dynamicly | ||||
| changing protocol data such as port numbers or user-agent strings. | ||||
| </strip> | ||||
| <protocol> | ||||
| the protocol dump curl should transmit | ||||
| <protocol [nonewline=yes]> | ||||
| the protocol dump curl should transmit, if 'nonewline' is set, we will cut | ||||
| off the trailing newline of this given data before comparing with the one | ||||
| actually sent by the client | ||||
| </protocol> | ||||
| <stdout> | ||||
| This verfies that this data was passed to stdout. | ||||
|   | ||||
| @@ -2,7 +2,7 @@ EXTRA_DIST = ftpserver.pl httpserver.pl httpsserver.pl runtests.pl \ | ||||
| 	     ftpsserver.pl stunnel.pm getpart.pm FILEFORMAT README \ | ||||
| 	     stunnel.pem | ||||
|  | ||||
| SUBDIRS = data | ||||
| SUBDIRS = data server | ||||
|  | ||||
| PERLFLAGS = -I$(srcdir) | ||||
|  | ||||
| @@ -12,11 +12,11 @@ install: | ||||
| curl: | ||||
| 	@(cd ..; make) | ||||
|  | ||||
| test: | ||||
| test: server/sws | ||||
| 	@cd data && exec $(MAKE) test | ||||
| 	srcdir=$(srcdir) $(PERL) $(PERLFLAGS) $(srcdir)/runtests.pl | ||||
|  | ||||
| quiet-test: | ||||
| quiet-test: server/sws | ||||
| 	@cd data && exec $(MAKE) test | ||||
| 	srcdir=$(srcdir) $(PERL) $(PERLFLAGS) $(srcdir)/runtests.pl -s -a | ||||
|  | ||||
| @@ -24,3 +24,5 @@ clean: | ||||
| 	rm -rf log | ||||
| 	find . -name "*~" | xargs rm -f | ||||
|  | ||||
| server/sws: | ||||
| 	cd server; make sws | ||||
|   | ||||
| @@ -10,7 +10,7 @@ | ||||
| use curl with multiple request methods | ||||
|  </name> | ||||
|  <command> | ||||
| -I -X FOOO localhost | ||||
| -I -d FOOO localhost | ||||
| </command> | ||||
| </test> | ||||
|  | ||||
|   | ||||
| @@ -28,7 +28,7 @@ HTTP POST with user and password | ||||
| <strip> | ||||
| ^User-Agent:.* | ||||
| </strip> | ||||
| <protocol> | ||||
| <protocol nonewline=yes> | ||||
| POST /3 HTTP/1.1 | ||||
| Authorization: Basic ZmFrZTotdXNlcg== | ||||
| Host: 127.0.0.1:8999 | ||||
| @@ -37,6 +37,6 @@ Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */* | ||||
| Content-Length: 37 | ||||
| Content-Type: application/x-www-form-urlencoded | ||||
|  | ||||
| fooo=mooo&pooo=clue&doo=%20%20%20++++ | ||||
| fooo=mooo&pooo=clue&doo=%20%20%20++++ | ||||
| </protocol> | ||||
| </verify> | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| #!/usr/bin/perl | ||||
| #!/usr/bin/env perl | ||||
| # $Id$ | ||||
| # | ||||
| # Main curl test script, in perl to run on more platforms | ||||
| @@ -22,7 +22,7 @@ my $FTPSPORT=8821;  # this is the FTPS server port | ||||
| my $CURL="../src/curl"; # what curl executable to run on the tests | ||||
| my $LOGDIR="log"; | ||||
| my $TESTDIR="data"; | ||||
| my $SERVERIN="$LOGDIR/http-request.dump"; # what curl sent the server | ||||
| my $SERVERIN="$LOGDIR/server.input"; # what curl sent the server | ||||
| my $CURLLOG="$LOGDIR/curl.log"; # all command lines run | ||||
| my $FTPDCMD="$LOGDIR/ftpserver.cmd"; # copy ftp server instructions here | ||||
|  | ||||
| @@ -140,16 +140,27 @@ sub runhttpserver { | ||||
|     my $RUNNING; | ||||
|     my $pid; | ||||
|  | ||||
|     $pid = checkserver ($HTTPPIDFILE); | ||||
|  | ||||
|     # verify if our/any server is running on this port | ||||
|     my $data=`$CURL --silent -i $HOSTIP:$HOSTPORT/verifiedserver`; | ||||
|  | ||||
|     if ( $data =~ /WE ROOLZ(: |)(\d*)/ ) { | ||||
|         $pid = 0+$2; | ||||
|         if($2) { | ||||
|             $pid = 0+$2; | ||||
|         } | ||||
|  | ||||
|         if(!$pid) { | ||||
|             print "Test server already running with unknown pid! Use it...\n"; | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         if($verbose) { | ||||
|             print "Test server already running with pid $pid, killing it...\n"; | ||||
|         } | ||||
|     } | ||||
|     elsif($data ne "") { | ||||
|         print "GOT: $data\n"; | ||||
|         print "An alien HTTP server is running on port $HOSTPORT\n", | ||||
|         "Edit runtests.pl to use another port and rerun the test script\n"; | ||||
|         exit; | ||||
| @@ -602,6 +613,15 @@ sub singletest { | ||||
|  | ||||
|         my @protstrip=@protocol; | ||||
|  | ||||
|         # check if there's any attributes on the verify/protocol section | ||||
|         my %hash = getpartattr("verify", "protocol"); | ||||
|  | ||||
|         if($hash{'nonewline'}) { | ||||
|             # Yes, we must cut off the final newline from the final line | ||||
|             # of the protocol data | ||||
|             chomp($protstrip[$#protstrip]); | ||||
|         } | ||||
|  | ||||
|         for(@strip) { | ||||
|             # strip all patterns from both arrays | ||||
|             @out = striparray( $_, \@out); | ||||
| @@ -835,36 +855,6 @@ if($testthis[0] ne "") { | ||||
|     $TESTCASES=join(" ", @testthis); | ||||
| } | ||||
|  | ||||
| ############################################################################ | ||||
| # | ||||
| # don't let anyone think this works right now | ||||
|  | ||||
| print <<EOM | ||||
|  *************************************************************************** | ||||
|  | ||||
|     THIS DOES NOT WORK | ||||
|  | ||||
|  *************************************************************************** | ||||
|  | ||||
|  Things in curl-land have changed, but the test suite has not been fixed | ||||
|  accordingly and thus, the test suite is currently more or less useless. | ||||
|  | ||||
|  *PLEASE* help us fixing this. We have to make our new test server written | ||||
|  in C work and get used instead of the perl version previously used. | ||||
|  | ||||
|  The working version of the test server is found in the tests/server | ||||
|  directory in the CVS tree. | ||||
|  | ||||
|  If you run this in the tests/ directory and run the server in there, you | ||||
|  can actually get test-responses if you do like this: | ||||
|  | ||||
|  \$ ./server/sws 8080 & | ||||
|  \$ curl localhost:8080/3 | ||||
|  | ||||
| EOM | ||||
|     ; | ||||
|  | ||||
|  | ||||
| ####################################################################### | ||||
| # Output curl version and host info being tested | ||||
| # | ||||
|   | ||||
| @@ -1,16 +0,0 @@ | ||||
| CC	= gcc | ||||
| CFLAGS	= -g -Wall | ||||
|  | ||||
| .PHONY: all clean | ||||
|  | ||||
| TARGET = sws | ||||
| OBJS= sws.o getpart.o | ||||
|  | ||||
| all: $(TARGET) | ||||
|  | ||||
| $(TARGET): $(OBJS) | ||||
| 	$(CC) $(LDFLAGS) -o $@ $^ | ||||
|  | ||||
| clean: | ||||
| 	-rm -f $(OBJS) *~ $(TARGET) core logfile | ||||
|  | ||||
							
								
								
									
										12
									
								
								tests/server/Makefile.am
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								tests/server/Makefile.am
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| # sws is the Silly Web Server | ||||
| # | ||||
| # Original http server code contributed by Georg Horn. Heavily modified since. | ||||
| # | ||||
|  | ||||
| AUTOMAKE_OPTIONS = foreign | ||||
|  | ||||
| noinst_PROGRAMS = sws | ||||
|  | ||||
| sws_SOURCES= sws.c getpart.c | ||||
|  | ||||
| extra_DIST = config.h.in | ||||
							
								
								
									
										2
									
								
								tests/server/config.h.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								tests/server/config.h.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | ||||
|  | ||||
| #undef HAVE_SIGNAL | ||||
| @@ -7,6 +7,13 @@ | ||||
| #define EAT_SPACE(ptr) while( ptr && *ptr && isspace(*ptr) ) ptr++ | ||||
| #define EAT_WORD(ptr) while( ptr && *ptr && !isspace(*ptr) && ('>' != *ptr)) ptr++ | ||||
|  | ||||
| #ifdef DEBUG | ||||
| #define show(x) printf x | ||||
| #else | ||||
| #define show(x) | ||||
| #endif | ||||
|  | ||||
| static | ||||
| char *appendstring(char *string, /* original string */ | ||||
|                    char *buffer, /* to append */ | ||||
|                    int *stringlen, int *stralloc) | ||||
| @@ -40,7 +47,6 @@ char *spitout(FILE *stream, char *main, char *sub, int *size) | ||||
|   char *string; | ||||
|   int stringlen=0; | ||||
|   int stralloc=256; | ||||
|   int len; | ||||
|  | ||||
|   enum { | ||||
|     STATE_OUTSIDE, | ||||
| @@ -60,9 +66,9 @@ char *spitout(FILE *stream, char *main, char *sub, int *size) | ||||
|  | ||||
|     if('<' != *ptr) { | ||||
|       if(display) { | ||||
|         printf("=> %s", buffer); | ||||
|         show(("=> %s", buffer)); | ||||
|         string = appendstring(string, buffer, &stringlen, &stralloc); | ||||
|         printf("* %s\n", buffer); | ||||
|         show(("* %s\n", buffer)); | ||||
|       } | ||||
|       continue; | ||||
|     } | ||||
| @@ -113,17 +119,17 @@ char *spitout(FILE *stream, char *main, char *sub, int *size) | ||||
|     } | ||||
|     if(display) { | ||||
|       string = appendstring(string, buffer, &stringlen, &stralloc); | ||||
|       printf("* %s\n", buffer); | ||||
|       show(("* %s\n", buffer)); | ||||
|     } | ||||
|  | ||||
|     if((STATE_INSUB == state) && | ||||
|        !strcmp(cmain, main) && | ||||
|        !strcmp(csub, sub)) { | ||||
|       printf("* (%d bytes) %s\n", stringlen, buffer); | ||||
|       show(("* (%d bytes) %s\n", stringlen, buffer)); | ||||
|       display = 1; /* start displaying */ | ||||
|     } | ||||
|     else { | ||||
|       printf("%d (%s/%s): %s\n", state, cmain, csub, buffer); | ||||
|       show(("%d (%s/%s): %s\n", state, cmain, csub, buffer)); | ||||
|       display = 0; /* no display */ | ||||
|     } | ||||
|   } | ||||
|   | ||||
| @@ -5,19 +5,19 @@ | ||||
| #include <string.h> | ||||
| #include <unistd.h> | ||||
| #include <signal.h> | ||||
| #include <getopt.h> | ||||
| #include <sys/time.h> | ||||
| #include <sys/types.h> | ||||
| #include <sys/wait.h> | ||||
| #include <sys/socket.h> | ||||
| #include <netinet/in.h> | ||||
| #include <netdb.h> | ||||
| #include <assert.h> | ||||
|  | ||||
| char *spitout(FILE *stream, char *main, char *sub, int *size); | ||||
|  | ||||
| #define DEFAULT_PORT 8999 | ||||
|  | ||||
| #ifndef DEFAULT_LOGFILE | ||||
| #define DEFAULT_LOGFILE "/dev/null" | ||||
| #define DEFAULT_LOGFILE "log/sws.log" | ||||
| #endif | ||||
|  | ||||
| #define DOCBUFSIZE 4 | ||||
| @@ -25,11 +25,11 @@ | ||||
|  | ||||
| #define VERSION "cURL test suite HTTP server/0.1" | ||||
|  | ||||
| #define REQUEST_DUMP "http-request.dump" | ||||
| #define REQUEST_DUMP "log/server.input" | ||||
|  | ||||
| #define TEST_DATA_PATH "data/test%d" | ||||
|  | ||||
| static char *docfriends = "WE ROOLZ\r\n"; | ||||
| static char *docfriends = "HTTP/1.1 200 Mighty fine indeed\r\n\r\nWE ROOLZ\r\n"; | ||||
| static char *doc404 = "HTTP/1.1 404 Not Found\n" | ||||
|     "Server: " VERSION "\n" | ||||
|     "Connection: close\n" | ||||
| @@ -56,7 +56,9 @@ static void logmsg(const char *msg) | ||||
|     strcpy(loctime, asctime(curr_time)); | ||||
|     loctime[strlen(loctime) - 1] = '\0'; | ||||
|     fprintf(logfp, "%s: pid %d: %s\n", loctime, getpid(), msg); | ||||
| #ifdef DEBUG | ||||
|     fprintf(stderr, "%s: pid %d: %s\n", loctime, getpid(), msg); | ||||
| #endif | ||||
|     fflush(logfp); | ||||
| } | ||||
|  | ||||
| @@ -78,7 +80,7 @@ static void sigterm_handler(int sig) | ||||
| int ProcessRequest(char *request) | ||||
| { | ||||
|   char *line=request; | ||||
|   long contentlength=-1; | ||||
|   unsigned long contentlength=0; | ||||
|  | ||||
| #define END_OF_HEADERS "\r\n\r\n" | ||||
|  | ||||
| @@ -109,7 +111,7 @@ int ProcessRequest(char *request) | ||||
|       line++; | ||||
|   } while(line); | ||||
|  | ||||
|   if(contentlength > -1 ) { | ||||
|   if(contentlength > 0 ) { | ||||
|     if(contentlength <= strlen(end+strlen(END_OF_HEADERS))) | ||||
|       return 1; /* done */ | ||||
|     else | ||||
| @@ -123,7 +125,7 @@ void storerequest(char *reqbuf) | ||||
| { | ||||
|   FILE *dump; | ||||
|  | ||||
|   dump = fopen(REQUEST_DUMP, "wb"); /* b is for windows-preparing */ | ||||
|   dump = fopen(REQUEST_DUMP, "ab"); /* b is for windows-preparing */ | ||||
|   if(dump) { | ||||
|     fwrite(reqbuf, 1, strlen(reqbuf), dump); | ||||
|  | ||||
| @@ -133,15 +135,23 @@ void storerequest(char *reqbuf) | ||||
| } | ||||
|  | ||||
|  | ||||
| #define REQBUFSIZ 4096 | ||||
| #define MAXDOCNAMELEN 1024 | ||||
| #define REQBUFSIZ 50000 | ||||
| #define REQBUFSIZ_TXT "49999" | ||||
|  | ||||
| /* very-big-path support */ | ||||
| #define MAXDOCNAMELEN 40000 | ||||
| #define MAXDOCNAMELEN_TXT "39999" | ||||
|  | ||||
| #define REQUEST_KEYWORD_SIZE 256 | ||||
| static int get_request(int sock) | ||||
| static int get_request(int sock, int *part) | ||||
| { | ||||
|   char reqbuf[REQBUFSIZ], doc[MAXDOCNAMELEN]; | ||||
|   char request[REQUEST_KEYWORD_SIZE]; | ||||
|   static char reqbuf[REQBUFSIZ], doc[MAXDOCNAMELEN]; | ||||
|   static char request[REQUEST_KEYWORD_SIZE]; | ||||
|   unsigned int offset = 0; | ||||
|   int prot_major, prot_minor; | ||||
|   char logbuf[256]; | ||||
|  | ||||
|   *part = 0; /* part zero equals none */ | ||||
|  | ||||
|   while (offset < REQBUFSIZ) { | ||||
|     int got = recv(sock, reqbuf + offset, REQBUFSIZ - offset, 0); | ||||
| @@ -172,7 +182,7 @@ static int get_request(int sock) | ||||
|   /* dump the request to an external file */ | ||||
|   storerequest(reqbuf); | ||||
|  | ||||
|   if (sscanf(reqbuf, "%s %s HTTP/%d.%d", | ||||
|   if (sscanf(reqbuf, "%" REQBUFSIZ_TXT"s %" MAXDOCNAMELEN_TXT "s HTTP/%d.%d", | ||||
|              request, | ||||
|              doc, | ||||
|              &prot_major, | ||||
| @@ -185,13 +195,31 @@ static int get_request(int sock) | ||||
|  | ||||
|     /* get the number after it */ | ||||
|     if(ptr) { | ||||
|       if(!strcmp("/verifiedserver", ptr)) { | ||||
|  | ||||
|       if((strlen(doc) + strlen(request)) < 200) | ||||
|         sprintf(logbuf, "Got request: %s %s HTTP/%d.%d", | ||||
|                 request, doc, prot_major, prot_minor); | ||||
|       else | ||||
|         sprintf(logbuf, "Got a *HUGE* request HTTP/%d.%d", | ||||
|                 prot_major, prot_minor); | ||||
|       logmsg(logbuf); | ||||
|        | ||||
|       if(!strncmp("/verifiedserver", ptr, 15)) { | ||||
|         logmsg("Are-we-friendly question received"); | ||||
|         return -2; | ||||
|       } | ||||
|       test_no = strtol(ptr+1, &ptr, 10); | ||||
|  | ||||
|       logmsg("Found test number in PATH"); | ||||
|       ptr++; /* skip the slash */ | ||||
|  | ||||
|       test_no = strtol(ptr, &ptr, 10); | ||||
|  | ||||
|       if(test_no > 10000) { | ||||
|         *part = test_no % 10000; | ||||
|         test_no /= 10000; | ||||
|       } | ||||
|  | ||||
|       sprintf(logbuf, "Found test number %d in path", test_no); | ||||
|       logmsg(logbuf); | ||||
|     } | ||||
|     else { | ||||
|  | ||||
| @@ -207,15 +235,18 @@ static int get_request(int sock) | ||||
| } | ||||
|  | ||||
|  | ||||
| static int send_doc(int sock, int doc) | ||||
| static int send_doc(int sock, int doc, int part_no) | ||||
| { | ||||
|   int written; | ||||
|   int count; | ||||
|   char *buffer; | ||||
|   char *ptr; | ||||
|   FILE *stream; | ||||
|   char *cmd=NULL; | ||||
|   int cmdsize; | ||||
|  | ||||
|   char filename[256]; | ||||
|   char partbuf[80]="data"; | ||||
|  | ||||
|   if(doc < 0) { | ||||
|     if(-2 == doc) | ||||
| @@ -225,8 +256,15 @@ static int send_doc(int sock, int doc) | ||||
|       buffer = doc404; | ||||
|     ptr = NULL; | ||||
|     stream=NULL; | ||||
|  | ||||
|     count = strlen(buffer); | ||||
|   } | ||||
|   else { | ||||
|     if(0 != part_no) { | ||||
|       sprintf(partbuf, "data%d", part_no); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     sprintf(filename, TEST_DATA_PATH, doc); | ||||
|  | ||||
|     stream=fopen(filename, "rb"); | ||||
| @@ -234,14 +272,27 @@ static int send_doc(int sock, int doc) | ||||
|       logmsg("Couldn't open test file"); | ||||
|       return 0; | ||||
|     } | ||||
|     else { | ||||
|       ptr = buffer = spitout(stream, "reply", partbuf, &count); | ||||
|       fclose(stream); | ||||
|     } | ||||
|  | ||||
|     ptr = buffer = spitout(stream, "reply", "data", &count); | ||||
|     /* re-open the same file again */ | ||||
|     stream=fopen(filename, "rb"); | ||||
|     if(!stream) { | ||||
|       logmsg("Couldn't open test file"); | ||||
|       return 0; | ||||
|     } | ||||
|     else {     | ||||
|       /* get the custom server control "commands" */ | ||||
|       cmd = spitout(stream, "reply", "postcmd", &cmdsize); | ||||
|       fclose(stream); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   do { | ||||
|     written = send(sock, buffer, count, 0); | ||||
|     if (written < 0) { | ||||
|       fclose(stream); | ||||
|       return -1; | ||||
|     } | ||||
|     count -= written; | ||||
| @@ -250,94 +301,125 @@ static int send_doc(int sock, int doc) | ||||
|  | ||||
|   if(ptr) | ||||
|     free(ptr); | ||||
|   if(stream) | ||||
|     fclose(stream); | ||||
|  | ||||
|   if(cmdsize > 0 ) { | ||||
|     char command[32]; | ||||
|     int num; | ||||
|     char *ptr=cmd; | ||||
|     do { | ||||
|       if(2 == sscanf(ptr, "%31s %d", command, &num)) { | ||||
|         if(!strcmp("wait", command)) | ||||
|           sleep(num); /* wait this many seconds */ | ||||
|         else { | ||||
|           logmsg("Unknown command in reply command section"); | ||||
|         } | ||||
|       } | ||||
|       ptr = strchr(ptr, '\n'); | ||||
|       if(ptr) | ||||
|         ptr++; | ||||
|       else | ||||
|         ptr = NULL; | ||||
|     } while(ptr && *ptr); | ||||
|   } | ||||
|   if(cmd) | ||||
|     free(cmd); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
| int main(int argc, char *argv[]) | ||||
| { | ||||
|     struct sockaddr_in me; | ||||
|     int sock, msgsock, flag; | ||||
|     unsigned short port = DEFAULT_PORT; | ||||
|     char *logfile = DEFAULT_LOGFILE; | ||||
|      | ||||
|     if(argc>1) | ||||
|       port = atoi(argv[1]); | ||||
|   struct sockaddr_in me; | ||||
|   int sock, msgsock, flag; | ||||
|   unsigned short port = DEFAULT_PORT; | ||||
|   char *logfile = DEFAULT_LOGFILE; | ||||
|   int part_no; | ||||
|   FILE *pidfile; | ||||
|    | ||||
|   if(argc>1) | ||||
|     port = atoi(argv[1]); | ||||
|  | ||||
|     logfile = "logfile"; | ||||
|   /* FIX: write our pid to a file name */ | ||||
|  | ||||
|     /* FIX: write our pid to a file name */ | ||||
|   logfp = fopen(logfile, "a"); | ||||
|   if (!logfp) { | ||||
|     perror(logfile); | ||||
|     exit(1); | ||||
|   } | ||||
|  | ||||
|     logfp = fopen(logfile, "a"); | ||||
|     if (!logfp) { | ||||
| 	perror(logfile); | ||||
| 	exit(1); | ||||
|     } | ||||
| #ifdef HAVE_SIGNAL | ||||
|   /* FIX: make a more portable signal handler */ | ||||
|   signal(SIGPIPE, sigpipe_handler); | ||||
|   signal(SIGINT, sigterm_handler); | ||||
|   signal(SIGTERM, sigterm_handler); | ||||
|  | ||||
|     signal(SIGPIPE, sigpipe_handler); | ||||
|     signal(SIGINT, sigterm_handler); | ||||
|     signal(SIGTERM, sigterm_handler); | ||||
|   siginterrupt(SIGPIPE, 1); | ||||
|   siginterrupt(SIGINT, 1); | ||||
|   siginterrupt(SIGTERM, 1); | ||||
| #endif | ||||
|  | ||||
|     siginterrupt(SIGPIPE, 1); | ||||
|     siginterrupt(SIGINT, 1); | ||||
|     siginterrupt(SIGTERM, 1); | ||||
|  | ||||
|     sock = socket(AF_INET, SOCK_STREAM, 0); | ||||
|     if (sock < 0) { | ||||
| 	perror("opening stream socket"); | ||||
| 	fprintf(logfp, "Error opening socket -- aborting\n"); | ||||
| 	fclose(logfp); | ||||
| 	exit(1); | ||||
|     } | ||||
|  | ||||
|     flag = 1; | ||||
|     if (setsockopt | ||||
| 	(sock, SOL_SOCKET, SO_REUSEADDR, (const void *) &flag, | ||||
| 	 sizeof(int)) < 0) { | ||||
| 	perror("setsockopt(SO_REUSEADDR)"); | ||||
|     } | ||||
|  | ||||
|     me.sin_family = AF_INET; | ||||
|     me.sin_addr.s_addr = INADDR_ANY; | ||||
|     me.sin_port = htons(port); | ||||
|     if (bind(sock, (struct sockaddr *) &me, sizeof me) < 0) { | ||||
| 	perror("binding stream socket"); | ||||
| 	fprintf(logfp, "Error binding socket -- aborting\n"); | ||||
| 	fclose(logfp); | ||||
| 	exit(1); | ||||
|     } | ||||
|  | ||||
|     /* start accepting connections */ | ||||
|     listen(sock, 5); | ||||
|  | ||||
|     printf("*** %s listening on port %u ***\n", VERSION, port); | ||||
|  | ||||
|     while (!sigterm) { | ||||
|       int doc; | ||||
|  | ||||
|       msgsock = accept(sock, NULL, NULL); | ||||
|        | ||||
|       if (msgsock == -1) { | ||||
|         if (sigterm) { | ||||
|           break; | ||||
|         } | ||||
|         /* perror("accept"); */ | ||||
|         continue; | ||||
|       } | ||||
|        | ||||
|       logmsg("New client connected"); | ||||
|  | ||||
|       doc = get_request(msgsock); | ||||
|       send_doc(msgsock, doc); | ||||
|  | ||||
|       close(msgsock); | ||||
|     } | ||||
|  | ||||
|     close(sock); | ||||
|   sock = socket(AF_INET, SOCK_STREAM, 0); | ||||
|   if (sock < 0) { | ||||
|     perror("opening stream socket"); | ||||
|     fprintf(logfp, "Error opening socket -- aborting\n"); | ||||
|     fclose(logfp); | ||||
|     exit(1); | ||||
|   } | ||||
|  | ||||
|     return 0; | ||||
|   flag = 1; | ||||
|   if (setsockopt | ||||
|       (sock, SOL_SOCKET, SO_REUSEADDR, (const void *) &flag, | ||||
|        sizeof(int)) < 0) { | ||||
|     perror("setsockopt(SO_REUSEADDR)"); | ||||
|   } | ||||
|  | ||||
|   me.sin_family = AF_INET; | ||||
|   me.sin_addr.s_addr = INADDR_ANY; | ||||
|   me.sin_port = htons(port); | ||||
|   if (bind(sock, (struct sockaddr *) &me, sizeof me) < 0) { | ||||
|     perror("binding stream socket"); | ||||
|     fprintf(logfp, "Error binding socket -- aborting\n"); | ||||
|     fclose(logfp); | ||||
|     exit(1); | ||||
|   } | ||||
|  | ||||
|   pidfile = fopen(".http.pid", "w"); | ||||
|   if(pidfile) { | ||||
|     fprintf(pidfile, "%d\n", (int)getpid()); | ||||
|     fclose(pidfile); | ||||
|   } | ||||
|   else | ||||
|     fprintf(stderr, "Couldn't write pid file\n"); | ||||
|  | ||||
|   /* start accepting connections */ | ||||
|   listen(sock, 5); | ||||
|  | ||||
|   fprintf(stderr, "*** %s listening on port %u ***\n", VERSION, port); | ||||
|  | ||||
|   while (!sigterm) { | ||||
|     int doc; | ||||
|  | ||||
|     msgsock = accept(sock, NULL, NULL); | ||||
|      | ||||
|     if (msgsock == -1) { | ||||
|       if (sigterm) { | ||||
|         break; | ||||
|       } | ||||
|       /* perror("accept"); */ | ||||
|       continue; | ||||
|     } | ||||
|      | ||||
|     logmsg("New client connected"); | ||||
|  | ||||
|     doc = get_request(msgsock, &part_no); | ||||
|     send_doc(msgsock, doc, part_no); | ||||
|  | ||||
|     close(msgsock); | ||||
|   } | ||||
|    | ||||
|   close(sock); | ||||
|   fclose(logfp); | ||||
|    | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user