|  | <testcase> | 
|  | <info> | 
|  | <keywords> | 
|  | HTTP | 
|  | HTTP PUT | 
|  | HTTP Digest auth | 
|  | --anyauth | 
|  | </keywords> | 
|  | </info> | 
|  |  | 
|  | # Server-side | 
|  | <reply> | 
|  | <servercmd> | 
|  | auth_required | 
|  | </servercmd> | 
|  | <data> | 
|  | HTTP/1.1 401 Authorization Required swsclose | 
|  | Server: Apache/1.3.27 (Darwin) PHP/4.1.2 | 
|  | WWW-Authenticate: Blackmagic realm="gimme all yer s3cr3ts" | 
|  | WWW-Authenticate: Basic realm="gimme all yer s3cr3ts" | 
|  | WWW-Authenticate: Digest realm="gimme all yer s3cr3ts", nonce="11223344" | 
|  | Content-Type: text/html; charset=iso-8859-1 | 
|  | Connection: close | 
|  |  | 
|  | This is not the real page | 
|  | </data> | 
|  |  | 
|  | # This is supposed to be returned when the server gets a | 
|  | # Authorization: Digest line passed-in from the client | 
|  | <data1000> | 
|  | HTTP/1.1 200 OK swsclose | 
|  | Server: Apache/1.3.27 (Darwin) PHP/4.1.2 | 
|  | Content-Type: text/html; charset=iso-8859-1 | 
|  | Content-Length: 23 | 
|  | Connection: close | 
|  |  | 
|  | This IS the real page! | 
|  | </data1000> | 
|  |  | 
|  | <datacheck> | 
|  | HTTP/1.1 401 Authorization Required swsclose | 
|  | Server: Apache/1.3.27 (Darwin) PHP/4.1.2 | 
|  | WWW-Authenticate: Blackmagic realm="gimme all yer s3cr3ts" | 
|  | WWW-Authenticate: Basic realm="gimme all yer s3cr3ts" | 
|  | WWW-Authenticate: Digest realm="gimme all yer s3cr3ts", nonce="11223344" | 
|  | Content-Type: text/html; charset=iso-8859-1 | 
|  | Connection: close | 
|  |  | 
|  | HTTP/1.1 200 OK swsclose | 
|  | Server: Apache/1.3.27 (Darwin) PHP/4.1.2 | 
|  | Content-Type: text/html; charset=iso-8859-1 | 
|  | Content-Length: 23 | 
|  | Connection: close | 
|  |  | 
|  | This IS the real page! | 
|  | </datacheck> | 
|  |  | 
|  | </reply> | 
|  |  | 
|  | # Client-side | 
|  | <client> | 
|  | <server> | 
|  | http | 
|  | </server> | 
|  | <features> | 
|  | !SSPI | 
|  | crypto | 
|  | </features> | 
|  | <name> | 
|  | HTTP PUT with --anyauth authorization (picking Digest) | 
|  | </name> | 
|  | <command> | 
|  | http://%HOSTIP:%HTTPPORT/%TESTNUMBER -T log/put%TESTNUMBER -u testuser:testpass --anyauth | 
|  | </command> | 
|  | <file name="log/put%TESTNUMBER"> | 
|  | This is data we upload with PUT | 
|  | a second line | 
|  | line three | 
|  | four is the number of lines | 
|  | </file> | 
|  | </client> | 
|  |  | 
|  | # Verify data after the test has been "shot" | 
|  | <verify> | 
|  | <protocol> | 
|  | PUT /%TESTNUMBER HTTP/1.1 | 
|  | Host: %HOSTIP:%HTTPPORT | 
|  | User-Agent: curl/%VERSION | 
|  | Accept: */* | 
|  | Content-Length: 85 | 
|  | Expect: 100-continue | 
|  |  | 
|  | PUT /%TESTNUMBER HTTP/1.1 | 
|  | Host: %HOSTIP:%HTTPPORT | 
|  | Authorization: Digest username="testuser", realm="gimme all yer s3cr3ts", nonce="11223344", uri="/%TESTNUMBER", response="b71551e12d1c456e47d8388ecb2edeca" | 
|  | User-Agent: curl/%VERSION | 
|  | Accept: */* | 
|  | Content-Length: 85 | 
|  | Expect: 100-continue | 
|  |  | 
|  | This is data we upload with PUT | 
|  | a second line | 
|  | line three | 
|  | four is the number of lines | 
|  | </protocol> | 
|  | </verify> | 
|  | </testcase> |