auto-throttle generate queue after job failures#31
Merged
Conversation
AutoGenerateQueueOptions now stacks a time-decaying penalty on top of the grants-derived baseline interval. Each JobStatus.FAILED signal from JobBatchChecker bumps the penalty by 500ms (capped at 10s); it decays linearly at 100ms per second back to baseline. Repeated failures stack on the already-decaying penalty, so sustained errors push the interval higher before it settles. Logs at INFO when the throttle kicks in. IQueueOptions gets default no-op reportFailure() / reportSuccess() methods so non-adaptive implementations are unaffected. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
JobChecker is still part of the public API for callers who want per-job polling without going through waitForCompletion(). Add an overload that takes the onJobFailure runnable and invoke it on FAILED detection, so a user wiring it up against AutoGenerateQueueOptions still gets throttled. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
Swap the fixed-interval QueueOptions for createAutoGenerate() so the benchmark drives the new failure-triggered slowdown path. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
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.
AutoGenerateQueueOptions now stacks a time-decaying penalty on top of the grants-derived baseline interval. Each JobStatus.FAILED signal from JobBatchChecker bumps the penalty by 500ms (capped at 10s); it decays linearly at 100ms per second back to baseline. Repeated failures stack on the already-decaying penalty, so sustained errors push the interval higher before it settles. Logs at INFO when the throttle kicks in.
IQueueOptions gets default no-op reportFailure() / reportSuccess() methods so non-adaptive implementations are unaffected.