micro/client/backoff_test.go

32 lines
538 B
Go
Raw Normal View History

2016-04-05 20:04:37 +01:00
package client
import (
2018-03-03 11:53:52 +00:00
"context"
2016-04-05 20:04:37 +01:00
"testing"
"time"
)
func TestBackoff(t *testing.T) {
2020-01-30 20:08:03 +03:00
results := []time.Duration{
0 * time.Second,
100 * time.Millisecond,
600 * time.Millisecond,
1900 * time.Millisecond,
4300 * time.Millisecond,
7900 * time.Millisecond,
}
2016-04-05 20:04:37 +01:00
2018-04-14 18:15:09 +01:00
c := NewClient()
2016-04-05 20:04:37 +01:00
for i := 0; i < 5; i++ {
2018-04-14 18:15:09 +01:00
d, err := exponentialBackoff(context.TODO(), c.NewRequest("test", "test", nil), i)
2016-04-05 20:04:37 +01:00
if err != nil {
t.Fatal(err)
}
2020-01-30 19:43:03 +03:00
if d != results[i] {
t.Fatalf("Expected equal than %v, got %v", results[i], d)
2016-04-05 20:04:37 +01:00
}
}
}