diff options
-rw-r--r-- | lib/url.c | 6 | ||||
-rw-r--r-- | tests/data/Makefile.am | 2 | ||||
-rw-r--r-- | tests/data/test1418 | 107 | ||||
-rw-r--r-- | tests/data/test1419 | 69 |
4 files changed, 181 insertions, 3 deletions
@@ -3133,8 +3133,10 @@ ConnectionExists(struct SessionHandle *data, *force_reuse = TRUE; break; } - else - continue; + else if(credentialsMatch) + /* this is a backup choice */ + chosen = check; + continue; } if(canPipeline) { diff --git a/tests/data/Makefile.am b/tests/data/Makefile.am index d526a4b69..53e8327fa 100644 --- a/tests/data/Makefile.am +++ b/tests/data/Makefile.am @@ -120,7 +120,7 @@ test1396 \ \ test1400 test1401 test1402 test1403 test1404 test1405 test1406 test1407 \ test1408 test1409 test1410 test1412 test1413 test1414 test1415 \ -test1416 test1417 \ +test1416 test1417 test1418 test1419 \ \ test1500 test1501 test1502 test1503 test1504 test1505 test1506 test1507 \ test1508 test1509 test1510 test1511 test1512 test1513 test1514 test1515 \ diff --git a/tests/data/test1418 b/tests/data/test1418 new file mode 100644 index 000000000..fb4e91a23 --- /dev/null +++ b/tests/data/test1418 @@ -0,0 +1,107 @@ +<testcase> +<info> +<keywords> +HTTP +HTTP GET +HTTP NTLM auth +connection re-use +</keywords> +</info> +# Server-side +<reply> +<servercmd> +connection-monitor +</servercmd> + +<data> +HTTP/1.1 401 Authentication please!
+Content-Length: 20
+WWW-Authenticate: Digest realm="loonie", nonce="314156592"
+WWW-Authenticate: Basic
+
+Please auth with me +</data> + +# This is supposed to be returned when the server gets the second +# Authorization: NTLM line passed-in from the client +<data1000> +HTTP/1.1 200 Things are fine in server land
+Server: Microsoft-IIS/5.0
+Content-Length: 4
+
+moo +</data1000> + +<data1003> +HTTP/1.1 200 OK
+Server: Another one/1.0
+Content-Length: 4
+
+boo +</data1003> + +# This is the first reply after the redirection +<data1011> +HTTP/1.1 200 OK
+Server: Microsoft-IIS/5.0
+Content-Type: text/html; charset=iso-8859-1
+Content-Length: 34
+
+This is not the real page either! +</data1011> + +<datacheck> +HTTP/1.1 401 Authentication please!
+Content-Length: 20
+WWW-Authenticate: Digest realm="loonie", nonce="314156592"
+WWW-Authenticate: Basic
+
+HTTP/1.1 200 Things are fine in server land
+Server: Microsoft-IIS/5.0
+Content-Length: 4
+
+moo +</datacheck> + +</reply> + +# Client-side +<client> +<server> +http +</server> +<features> +crypto +</features> + <name> +HTTP with --anyauth and connection re-use + </name> + <command> +http://%HOSTIP:%HTTPPORT/1418 -u testuser:testpass --anyauth http://%HOSTIP:%HTTPPORT/14180003 +</command> +</client> + +# Verify data after the test has been "shot" +<verify> +<strip> +^User-Agent:.* +</strip> +<protocol> +GET /1418 HTTP/1.1
+Host: %HOSTIP:%HTTPPORT
+Accept: */*
+
+GET /1418 HTTP/1.1
+Authorization: Digest username="testuser", realm="loonie", nonce="314156592", uri="/1418", response="986238b7e0077754944c966f56d9bc77"
+Host: %HOSTIP:%HTTPPORT
+Accept: */*
+
+GET /14180003 HTTP/1.1
+Authorization: Digest username="testuser", realm="loonie", nonce="314156592", uri="/14180003", response="1c6390a67bac3283a9b023402f3b3540"
+Host: %HOSTIP:%HTTPPORT
+Accept: */*
+
+[DISCONNECT] +</protocol> +</verify> +</testcase> diff --git a/tests/data/test1419 b/tests/data/test1419 new file mode 100644 index 000000000..f29ce4444 --- /dev/null +++ b/tests/data/test1419 @@ -0,0 +1,69 @@ +<testcase> +<info> +<keywords> +HTTP +HTTP GET +HTTP NTLM auth +connection re-use +</keywords> +</info> +# Server-side +<reply> +<servercmd> +connection-monitor +</servercmd> + +<data> +HTTP/1.1 200 fine!
+Content-Length: 20
+
+Feel free to get it +</data> + +<data3> +HTTP/1.1 200 OK
+Server: Another one/1.0
+Content-Length: 4
+
+boo +</data3> + +<datacheck> +HTTP/1.1 200 fine!
+Content-Length: 20
+
+Feel free to get it +</datacheck> +</reply> + +# Client-side +<client> +<server> +http +</server> + <name> +HTTP with --anyauth (but no auth!) and connection re-use + </name> + <command> +http://%HOSTIP:%HTTPPORT/1419 --anyauth http://%HOSTIP:%HTTPPORT/14190003 +</command> +</client> + +# Verify data after the test has been "shot" +<verify> +<strip> +^User-Agent:.* +</strip> +<protocol> +GET /1419 HTTP/1.1
+Host: %HOSTIP:%HTTPPORT
+Accept: */*
+
+GET /14190003 HTTP/1.1
+Host: %HOSTIP:%HTTPPORT
+Accept: */*
+
+[DISCONNECT] +</protocol> +</verify> +</testcase> |