feat: retry on 503, add Retry-After date (RFC1123) support #7305
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
This PR introduces a
with503Retryhigher-order function that wraps fetch and provides robust, spec-aligned retry handling for HTTP 503 Service Unavailable responses. It retries only on 503s, passes all other responses through untouched, and fully honors any provided AbortSignal.Key Features
MAX_RETRIES = 5retry attempts for 503 responses.getRetryAfterMs) or seconds (getRetryAfterSeconds) with clear unit types in name.MAX_DELAY_MS = 60_000to avoid pathological server values.BASE_DELAY_MS = 500Motivations
Retry-Aftersupport ensures compliance with server instructions and avoids piling onto a recovering subsystem.Implementation Notes
getRetryAfterMsis strict, predictable, and does not attempt to interpret exotic date formats beyond what Date can parse.Next Steps / Possible Future Improvements
Checklist
pnpm testruns as expected.pnpm buildruns as expected.Type of change