Chromium Code Reviews| Index: net/http/http_stream_parser.cc | 
| diff --git a/net/http/http_stream_parser.cc b/net/http/http_stream_parser.cc | 
| index 8098a18fec3e53a272c648887fdcac9c79204da6..700ec638bcfdfa0095b5b2f37ebb04bffe1575f3 100644 | 
| --- a/net/http/http_stream_parser.cc | 
| +++ b/net/http/http_stream_parser.cc | 
| @@ -662,12 +662,37 @@ int HttpStreamParser::DoReadBody() { | 
| } | 
| int HttpStreamParser::DoReadBodyComplete(int result) { | 
| - // If we didn't get a Content-Length and aren't using a chunked encoding, | 
| - // the only way to signal the end of a stream is to close the connection, | 
| - // so we don't treat that as an error, though in some cases we may not | 
| - // have completely received the resource. | 
| - if (result == 0 && !IsResponseBodyComplete() && CanFindEndOfResponse()) | 
| - result = ERR_CONNECTION_CLOSED; | 
| + // When the connection is closed, there are numerous ways to interpret it. | 
| + // | 
| + // - If a Content-Length header is present and the body contains exactly that | 
| + // number of bytes at connection close, the response is successful. | 
| + // | 
| + // - If a Content-Length header is present and the body contains fewer bytes | 
| + // than promised by the header at connection close, it may indicate that | 
| + // the connection was closed prematurely, or it may indicate that the | 
| + // server sent an invalid Content-Length header. Unfortunately, the invalid | 
| + // Content-Length header case does occur in practice and other browsers are | 
| + // tolerant of it, so this is reported as OK. | 
| 
 
wtc1
2012/03/26 21:37:02
If we report OK only for non-HTTPS, will that prov
 
cbentzel
2012/03/27 17:57:42
We'd have to measure this. As discussed off of thi
 
 | 
| + // | 
| + // - If chunked encoding is used and the terminating chunk has been processed | 
| + // when the connection is closed, the response is successful. | 
| + // | 
| + // - If chunked encoding is used and the terminating chunk has not been | 
| + // processed when the connection is closed, it may indicate that the | 
| + // connection was closed prematurely or it may indicate that the server | 
| + // sent an invalid chunked encoding. We choose to treat it as | 
| + // an invalid chunked encoding. | 
| + // | 
| + // - If a Content-Length is not present and chunked encoding is not used, | 
| + // connection close is the only way to signal that the response is | 
| + // complete. Unfortunately, this also means that there is no way to detect | 
| + // early close of a connection. No error is returned. | 
| + if (result == 0 && !IsResponseBodyComplete() && CanFindEndOfResponse()) { | 
| + if (chunked_decoder_.get()) | 
| + result = ERR_INVALID_CHUNKED_ENCODING; | 
| 
 
wtc1
2012/03/26 21:37:02
Perhaps ERR_INCOMPLETE_CHUNKED_ENCODING so we can
 
 | 
| + else | 
| + result = OK; | 
| + } | 
| // Filter incoming data if appropriate. FilterBuf may return an error. | 
| if (result > 0 && chunked_decoder_.get()) { |