From e4b733e3f1a771bd1017cdcfb355fcb9caffe646 Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Fri, 15 Mar 2013 14:18:16 +0100 Subject: HTTP proxy: insert slash in URL if missing curl has been accepting URLs using slightly wrong syntax for a long time, such as when completely missing as slash "http://example.org" or missing a slash when a query part is given "http://example.org?q=foobar". curl would translate these into a legitimate HTTP request to servers, although as was shown in bug #1206 it was not adjusted properly in the cases where a HTTP proxy was used. Test 1213 and 1214 were added to the test suite to verify this fix. The test HTTP server was adjusted to allow us to specify test number in the host name only without using any slashes in a given URL. Bug: http://curl.haxx.se/bug/view.cgi?id=1206 Reported by: ScottJi --- tests/data/Makefile.am | 2 +- tests/data/test1213 | 53 ++++++++++++++++++++++++++++++++++++++++++++++++++ tests/data/test1214 | 53 ++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 107 insertions(+), 1 deletion(-) create mode 100644 tests/data/test1213 create mode 100644 tests/data/test1214 (limited to 'tests/data') diff --git a/tests/data/Makefile.am b/tests/data/Makefile.am index 7c2e648f5..04a6aa631 100644 --- a/tests/data/Makefile.am +++ b/tests/data/Makefile.am @@ -77,7 +77,7 @@ test1110 test1111 test1112 test1113 test1114 test1115 test1116 test1117 \ test1118 test1119 test1120 test1121 test1122 test1123 test1124 test1125 \ test1126 test1127 test1128 test1129 test1130 test1131 test1132 test1133 \ test1200 test1201 test1202 test1203 test1204 test1205 test1206 test1207 \ -test1208 test1209 test1210 test1211 test1212 \ +test1208 test1209 test1210 test1211 test1212 test1213 test1214 \ test1220 test1221 test1222 test1223 \ test1300 test1301 test1302 test1303 test1304 test1305 \ test1306 test1307 test1308 test1309 test1310 test1311 test1312 test1313 \ diff --git a/tests/data/test1213 b/tests/data/test1213 new file mode 100644 index 000000000..729a7034d --- /dev/null +++ b/tests/data/test1213 @@ -0,0 +1,53 @@ + + + +HTTP +HTTP GET +HTTP proxy + + + +# Server-side + + +HTTP/1.1 200 OK +Date: Thu, 09 Nov 2010 14:49:00 GMT +Server: test-server/fake +Content-Type: text/html +Funny-head: yesyes +Content-Length: 22 + +the content goes here + + + +# Client-side + + +http + + +HTTP with proxy and host-only URL + +# the thing here is that this sloppy form is accepted and we convert it +# for normal server use, and we need to make sure it gets converted to +# RFC style even for proxies + +-x %HOSTIP:%HTTPPORT we.want.that.site.com.1213 + + + +# Verify data after the test has been "shot" + + +^User-Agent:.* + + +GET HTTP://we.want.that.site.com.1213/ HTTP/1.1 +Host: we.want.that.site.com.1213 +Accept: */* +Proxy-Connection: Keep-Alive + + + + diff --git a/tests/data/test1214 b/tests/data/test1214 new file mode 100644 index 000000000..3eeb3e3ad --- /dev/null +++ b/tests/data/test1214 @@ -0,0 +1,53 @@ + + + +HTTP +HTTP GET +HTTP proxy + + + +# Server-side + + +HTTP/1.1 200 OK +Date: Thu, 09 Nov 2010 14:49:00 GMT +Server: test-server/fake +Content-Type: text/html +Funny-head: yesyes +Content-Length: 22 + +the content goes here + + + +# Client-side + + +http + + +HTTP with proxy and URL with ? and no slash separator + +# the thing here is that this sloppy form is accepted and we convert it +# for normal server use, and we need to make sure it gets converted to +# RFC style even for proxies + +-x %HOSTIP:%HTTPPORT http://we.want.that.site.com.1214?moo=foo + + + +# Verify data after the test has been "shot" + + +^User-Agent:.* + + +GET http://we.want.that.site.com.1214/?moo=foo HTTP/1.1 +Host: we.want.that.site.com.1214 +Accept: */* +Proxy-Connection: Keep-Alive + + + + -- cgit v1.2.3