fix #4788 moving retry logic into the standard layer #4825
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Description
Fix #4788
This makes the retry logic common for all requests -
sendAsync
,consumeBytes
, and websockets. There wasn't a great way of making the client executor available due to when the httpclient is created vs when the executor is obtained - further refactoring could probably make this work, but for now since the httpclient calls are non-blocking I'm just running the delayed task in the scheduling thread.@manusa see if you want to refine the max connections test based upon this.
This does blur the line between the request and watch retries. Low level issues can be handled by the request retry, while higher level ones, such as repeated error status responses would still need to be handled by the watch retry.
Type of change
test, version modification, documentation, etc.)
Checklist