1 <testcase> 2 <info> 3 <keywords> 4 HTTP 5 HTTP GET 6 HTTP proxy 7 HTTP proxy NTLM auth 8 </keywords> 9 </info> 10 11 # Server-side 12 <reply> 13 14 # This is supposed to be returned when the server gets a first 15 # Authorization: NTLM line passed-in from the client 16 <data1001> 17 HTTP/1.1 407 Now gimme that second request of crap 18 Server: Microsoft-IIS/5.0 19 Content-Type: text/html; charset=iso-8859-1 20 Content-Length: 34 21 Proxy-Authenticate: NTLM TlRMTVNTUAACAAAAAgACADAAAAAGgoEAc51AYVDgyNcAAAAAAAAAAG4AbgAyAAAAQ0MCAAQAQwBDAAEAEgBFAEwASQBTAEEAQgBFAFQASAAEABgAYwBjAC4AaQBjAGUAZABlAHYALgBuAHUAAwAsAGUAbABpAHMAYQBiAGUAdABoAC4AYwBjAC4AaQBjAGUAZABlAHYALgBuAHUAAAAAAA== 22 23 This is not the real page either! 24 </data1001> 25 26 # This is supposed to be returned when the server gets the second 27 # Authorization: NTLM line passed-in from the client 28 <data1002> 29 HTTP/1.1 200 Things are fine in server land swsclose 30 Server: Microsoft-IIS/5.0 31 Content-Type: text/html; charset=iso-8859-1 32 Content-Length: 32 33 34 Finally, this is the real page! 35 </data1002> 36 37 <datacheck> 38 HTTP/1.1 407 Now gimme that second request of crap 39 Server: Microsoft-IIS/5.0 40 Content-Type: text/html; charset=iso-8859-1 41 Content-Length: 34 42 Proxy-Authenticate: NTLM TlRMTVNTUAACAAAAAgACADAAAAAGgoEAc51AYVDgyNcAAAAAAAAAAG4AbgAyAAAAQ0MCAAQAQwBDAAEAEgBFAEwASQBTAEEAQgBFAFQASAAEABgAYwBjAC4AaQBjAGUAZABlAHYALgBuAHUAAwAsAGUAbABpAHMAYQBiAGUAdABoAC4AYwBjAC4AaQBjAGUAZABlAHYALgBuAHUAAAAAAA== 43 44 HTTP/1.1 200 Things are fine in server land swsclose 45 Server: Microsoft-IIS/5.0 46 Content-Type: text/html; charset=iso-8859-1 47 Content-Length: 32 48 49 Finally, this is the real page! 50 </datacheck> 51 52 </reply> 53 54 # Client-side 55 <client> 56 <features> 57 NTLM 58 !SSPI 59 debug 60 </features> 61 <server> 62 http 63 </server> 64 <name> 65 HTTP with proxy using NTLM authorization 66 </name> 67 <setenv> 68 # we force our own host name, in order to make the test machine independent 69 CURL_GETHOSTNAME=curlhost 70 # we try to use the LD_PRELOAD hack, if not a debug build 71 LD_PRELOAD=%PWD/libtest/.libs/libhostname.so 72 </setenv> 73 <command> 74 http://%HOSTIP:%HTTPPORT/81 --proxy-user testuser:testpass -x http://%HOSTIP:%HTTPPORT --proxy-ntlm 75 </command> 76 <precheck> 77 chkhostname curlhost 78 </precheck> 79 </client> 80 81 # Verify data after the test has been "shot" 82 <verify> 83 <strip> 84 ^User-Agent:.* 85 </strip> 86 <protocol> 87 GET http://%HOSTIP:%HTTPPORT/81 HTTP/1.1 88 Host: %HOSTIP:%HTTPPORT 89 Proxy-Authorization: NTLM TlRMTVNTUAABAAAABoIIAAAAAAAAAAAAAAAAAAAAAAA= 90 User-Agent: curl/7.10.6-pre1 (i686-pc-linux-gnu) libcurl/7.10.6-pre1 OpenSSL/0.9.7a ipv6 zlib/1.1.3 91 Accept: */* 92 Proxy-Connection: Keep-Alive 93 94 GET http://%HOSTIP:%HTTPPORT/81 HTTP/1.1 95 Host: %HOSTIP:%HTTPPORT 96 Proxy-Authorization: NTLM TlRMTVNTUAADAAAAGAAYAEAAAACeAJ4AWAAAAAAAAAD2AAAACAAIAPYAAAAIAAgA/gAAAAAAAAAAAAAABoKBAMOv20GsURsat8gdH/RfnYI0MzIxNTMyMeCdd8AzFZLZ/N1ujmilmCcBAQAAAAAAAACAPtXesZ0BNDMyMTUzMjEAAAAAAgAEAEMAQwABABIARQBMAEkAUwBBAEIARQBUAEgABAAYAGMAYwAuAGkAYwBlAGQAZQB2AC4AbgB1AAMALABlAGwAaQBzAGEAYgBlAHQAaAAuAGMAYwAuAGkAYwBlAGQAZQB2AC4AbgB1AAAAAAAAAAAAdGVzdHVzZXJjdXJsaG9zdA== 97 User-Agent: curl/7.10.6-pre1 (i686-pc-linux-gnu) libcurl/7.10.6-pre1 OpenSSL/0.9.7a ipv6 zlib/1.1.3 98 Accept: */* 99 Proxy-Connection: Keep-Alive 100 101 </protocol> 102 </verify> 103 </testcase> 104