From 2883214e7913608fee7745190db127eacec015ae Mon Sep 17 00:00:00 2001 From: Martin Angers Date: Sat, 2 Mar 2024 17:31:06 -0500 Subject: [PATCH] Document that the generator function must be safe for concurrent use --- rehttp.go | 3 +++ 1 file changed, 3 insertions(+) diff --git a/rehttp.go b/rehttp.go index 8ad2950..394be84 100644 --- a/rehttp.go +++ b/rehttp.go @@ -11,6 +11,7 @@ // return a DelayFn: // - ConstDelay(delay time.Duration) DelayFn // - ExpJitterDelay(base, max time.Duration) DelayFn +// - ExpJitterDelayWithRand(base, max time.Duration, generator func(int64) int64) DelayFn // // It also provides common retry helpers that return a RetryFn: // - RetryIsErr(func(error) bool) RetryFn @@ -270,6 +271,8 @@ func ExpJitterDelay(base, max time.Duration) DelayFn { // between 0 and base * 2^attempt capped at max (an exponential // backoff delay with jitter). The generator argument is expected // to generate a random int64 in the half open interval [0, n). +// It is the caller's responsibility to ensure that the function is +// safe for concurrent use. // // See the full jitter algorithm in: // http://www.awsarchitectureblog.com/2015/03/backoff.html