diff options
author | Arne Juul <arnej@verizonmedia.com> | 2021-02-24 14:58:28 +0000 |
---|---|---|
committer | Arne Juul <arnej@verizonmedia.com> | 2021-02-24 14:58:28 +0000 |
commit | b4125a53f50194642e1aec9c97526e04856523b5 (patch) | |
tree | 8e511c9c12b0483fbd1c2e6a5482b238ff7b38fb /fbench | |
parent | 38beecb43c8dfc15af8f3b14a62ee29430689713 (diff) |
handle HTTP response with Content-Length: 0
Diffstat (limited to 'fbench')
-rw-r--r-- | fbench/src/httpclient/httpclient.cpp | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/fbench/src/httpclient/httpclient.cpp b/fbench/src/httpclient/httpclient.cpp index 88ae6a0aa81..ea10ff14269 100644 --- a/fbench/src/httpclient/httpclient.cpp +++ b/fbench/src/httpclient/httpclient.cpp @@ -414,15 +414,16 @@ HTTPClient::ContentLengthReader::Read(HTTPClient &client, client._bufpos += fromBuffer; client._dataRead += fromBuffer; res = fromBuffer; - if (client._dataRead >= client._contentLength) { - client._dataDone = true; - return res; - } + } + if (client._dataRead >= client._contentLength) { + client._dataDone = true; + return res; } if ((len - fromBuffer) > (len >> 1)) { readLen = (len - fromBuffer < client._contentLength - client._dataRead) ? len - fromBuffer : client._contentLength - client._dataRead; + assert(readLen > 0); readRes = client._socket->read(static_cast<char *>(buf) + fromBuffer, readLen); if (readRes < 0) { |