Skip to content

Commit

Permalink
Merge pull request #2642 from locustio/fix-issue-with-fasthttpuser-wi…
Browse files Browse the repository at this point in the history
…th-stream-true-and-connection-error

Dont throw an exception in FastHttpUser if a request is made with stream=True and the connection fails
  • Loading branch information
cyberw authored Mar 18, 2024
2 parents c69316d + 63bfdc7 commit 76575c9
Showing 1 changed file with 5 additions and 3 deletions.
8 changes: 5 additions & 3 deletions locust/contrib/fasthttp.py
Original file line number Diff line number Diff line change
Expand Up @@ -230,16 +230,18 @@ def request(
if not allow_redirects:
self.client.redirect_resonse_codes = old_redirect_response_codes

request_meta["response_length"] = 0 # default value, if length cannot be determined

# get the length of the content, but if the argument stream is set to True, we take
# the size from the content-length header, in order to not trigger fetching of the body
if stream:
request_meta["response_length"] = int(response.headers.get("response_length") or 0)
if response.headers and "response_length" in response.headers:
request_meta["response_length"] = int(response.headers["response_length"])
else:
try:
request_meta["response_length"] = len(response.content or "")
request_meta["response_length"] = len(response.content) if response.content else 0
except HTTPParseError as e:
request_meta["response_time"] = (time.perf_counter() - start_perf_counter) * 1000
request_meta["response_length"] = 0
request_meta["exception"] = e
self.environment.events.request.fire(**request_meta)
return response
Expand Down

0 comments on commit 76575c9

Please sign in to comment.