|  | <testcase> | 
|  | <info> | 
|  | <keywords> | 
|  | HTTP | 
|  | HTTP GET | 
|  | HTTP Digest auth | 
|  | </keywords> | 
|  | </info> | 
|  |  | 
|  | # Server-side | 
|  | <reply> | 
|  | <data> | 
|  | HTTP/1.1 401 Authorization Required swsclose | 
|  | Server: Apache/1.3.27 (Darwin) PHP/4.1.2 | 
|  | WWW-Authenticate: Digest realm="testrealm", nonce="1053604145" | 
|  | Content-Type: text/plain; charset=iso-8859-1 | 
|  | Content-Length: 26 | 
|  |  | 
|  | 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 | 
|  | # Send nothing to force an error code 52 reply | 
|  | <data1000> | 
|  | </data1000> | 
|  |  | 
|  | <datacheck> | 
|  | HTTP/1.1 401 Authorization Required swsclose | 
|  | Server: Apache/1.3.27 (Darwin) PHP/4.1.2 | 
|  | WWW-Authenticate: Digest realm="testrealm", nonce="1053604145" | 
|  | Content-Type: text/plain; charset=iso-8859-1 | 
|  | Content-Length: 26 | 
|  |  | 
|  | </datacheck> | 
|  |  | 
|  | </reply> | 
|  |  | 
|  | # Client-side | 
|  | <client> | 
|  | <server> | 
|  | http | 
|  | </server> | 
|  | <features> | 
|  | crypto | 
|  | </features> | 
|  | <name> | 
|  | HTTP retry after closed connection and empty response | 
|  | </name> | 
|  | <command> | 
|  | http://%HOSTIP:%HTTPPORT/1079 -u testuser:testpass --digest | 
|  | </command> | 
|  | </client> | 
|  |  | 
|  | # Verify data after the test has been "shot" | 
|  | <verify> | 
|  | <errorcode> | 
|  | 52 | 
|  | </errorcode> | 
|  | <strip> | 
|  | ^User-Agent:.* | 
|  | </strip> | 
|  | <protocol> | 
|  | GET /1079 HTTP/1.1 | 
|  | Host: %HOSTIP:%HTTPPORT | 
|  | Accept: */* | 
|  |  | 
|  | GET /1079 HTTP/1.1 | 
|  | Authorization: Digest username="testuser", realm="testrealm", nonce="1053604145", uri="/1079", response="e340c7cdca0950462070f46ee139e9f7" | 
|  | Host: %HOSTIP:%HTTPPORT | 
|  | Accept: */* | 
|  |  | 
|  | </protocol> | 
|  | </verify> | 
|  | </testcase> |