2014-06-30 20:03:27 -05:00
|
|
|
package resource
|
|
|
|
|
|
|
|
import (
|
2014-10-07 23:44:51 -05:00
|
|
|
"fmt"
|
2014-06-30 20:03:27 -05:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2014-10-07 23:44:51 -05:00
|
|
|
func TestRetry(t *testing.T) {
|
|
|
|
t.Parallel()
|
2014-06-30 20:03:27 -05:00
|
|
|
|
2014-10-07 23:44:51 -05:00
|
|
|
tries := 0
|
2016-03-09 16:53:32 -06:00
|
|
|
f := func() *RetryError {
|
2014-10-07 23:44:51 -05:00
|
|
|
tries++
|
2016-03-10 08:10:34 -06:00
|
|
|
if tries == 3 {
|
2014-10-07 23:44:51 -05:00
|
|
|
return nil
|
|
|
|
}
|
2014-06-30 20:03:27 -05:00
|
|
|
|
2016-03-09 16:53:32 -06:00
|
|
|
return RetryableError(fmt.Errorf("error"))
|
2014-06-30 20:03:27 -05:00
|
|
|
}
|
|
|
|
|
2016-03-10 08:10:34 -06:00
|
|
|
err := Retry(10*time.Second, f)
|
2014-06-30 20:03:27 -05:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
2014-07-07 17:21:54 -05:00
|
|
|
}
|
|
|
|
|
2017-04-19 11:14:23 -05:00
|
|
|
// make sure a slow StateRefreshFunc is allowed to complete after timeout
|
|
|
|
func TestRetry_grace(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
f := func() *RetryError {
|
|
|
|
time.Sleep(1 * time.Second)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
err := Retry(10*time.Millisecond, f)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-10-07 23:44:51 -05:00
|
|
|
func TestRetry_timeout(t *testing.T) {
|
|
|
|
t.Parallel()
|
2014-06-30 20:18:36 -05:00
|
|
|
|
2016-03-09 16:53:32 -06:00
|
|
|
f := func() *RetryError {
|
|
|
|
return RetryableError(fmt.Errorf("always"))
|
2014-06-30 20:03:27 -05:00
|
|
|
}
|
|
|
|
|
2014-10-10 16:50:35 -05:00
|
|
|
err := Retry(1*time.Second, f)
|
2014-10-07 23:44:51 -05:00
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should error")
|
2014-06-30 20:18:36 -05:00
|
|
|
}
|
2014-06-30 20:03:27 -05:00
|
|
|
}
|
2014-10-17 20:28:03 -05:00
|
|
|
|
2016-06-30 20:07:56 -05:00
|
|
|
func TestRetry_hang(t *testing.T) {
|
2017-04-19 13:19:08 -05:00
|
|
|
old := refreshGracePeriod
|
|
|
|
refreshGracePeriod = 50 * time.Millisecond
|
|
|
|
defer func() {
|
|
|
|
refreshGracePeriod = old
|
|
|
|
}()
|
2016-06-30 20:07:56 -05:00
|
|
|
|
|
|
|
f := func() *RetryError {
|
|
|
|
time.Sleep(2 * time.Second)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2017-04-19 13:19:08 -05:00
|
|
|
err := Retry(50*time.Millisecond, f)
|
2016-06-30 20:07:56 -05:00
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should error")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-10-17 20:28:03 -05:00
|
|
|
func TestRetry_error(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
expected := fmt.Errorf("nope")
|
2016-03-09 16:53:32 -06:00
|
|
|
f := func() *RetryError {
|
|
|
|
return NonRetryableError(expected)
|
2014-10-17 20:28:03 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
errCh := make(chan error)
|
|
|
|
go func() {
|
|
|
|
errCh <- Retry(1*time.Second, f)
|
|
|
|
}()
|
|
|
|
|
|
|
|
select {
|
|
|
|
case err := <-errCh:
|
|
|
|
if err != expected {
|
|
|
|
t.Fatalf("bad: %#v", err)
|
|
|
|
}
|
|
|
|
case <-time.After(5 * time.Second):
|
|
|
|
t.Fatal("timeout")
|
|
|
|
}
|
|
|
|
}
|