| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- package retry_test
- import (
- "testing"
- "time"
- "v2ray.com/core/common"
- "v2ray.com/core/common/errors"
- . "v2ray.com/core/common/retry"
- . "v2ray.com/ext/assert"
- )
- var (
- errorTestOnly = errors.New("This is a fake error.")
- )
- func TestNoRetry(t *testing.T) {
- assert := With(t)
- startTime := time.Now().Unix()
- err := Timed(10, 100000).On(func() error {
- return nil
- })
- endTime := time.Now().Unix()
- common.Must(err)
- assert(endTime-startTime, AtLeast, int64(0))
- }
- func TestRetryOnce(t *testing.T) {
- assert := With(t)
- startTime := time.Now()
- called := 0
- err := Timed(10, 1000).On(func() error {
- if called == 0 {
- called++
- return errorTestOnly
- }
- return nil
- })
- duration := time.Since(startTime)
- common.Must(err)
- assert(int64(duration/time.Millisecond), AtLeast, int64(900))
- }
- func TestRetryMultiple(t *testing.T) {
- assert := With(t)
- startTime := time.Now()
- called := 0
- err := Timed(10, 1000).On(func() error {
- if called < 5 {
- called++
- return errorTestOnly
- }
- return nil
- })
- duration := time.Since(startTime)
- common.Must(err)
- assert(int64(duration/time.Millisecond), AtLeast, int64(4900))
- }
- func TestRetryExhausted(t *testing.T) {
- assert := With(t)
- startTime := time.Now()
- called := 0
- err := Timed(2, 1000).On(func() error {
- called++
- return errorTestOnly
- })
- duration := time.Since(startTime)
- assert(errors.Cause(err), Equals, ErrRetryFailed)
- assert(int64(duration/time.Millisecond), AtLeast, int64(1900))
- }
- func TestExponentialBackoff(t *testing.T) {
- assert := With(t)
- startTime := time.Now()
- called := 0
- err := ExponentialBackoff(10, 100).On(func() error {
- called++
- return errorTestOnly
- })
- duration := time.Since(startTime)
- assert(errors.Cause(err), Equals, ErrRetryFailed)
- assert(int64(duration/time.Millisecond), AtLeast, int64(4000))
- }
|