| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 | 
							- package retry_test
 
- import (
 
- 	"errors"
 
- 	"testing"
 
- 	"time"
 
- 	. "github.com/v2ray/v2ray-core/common/retry"
 
- 	v2testing "github.com/v2ray/v2ray-core/testing"
 
- 	"github.com/v2ray/v2ray-core/testing/assert"
 
- )
 
- var (
 
- 	errorTestOnly = errors.New("This is a fake error.")
 
- )
 
- func TestNoRetry(t *testing.T) {
 
- 	v2testing.Current(t)
 
- 	startTime := time.Now().Unix()
 
- 	err := Timed(10, 100000).On(func() error {
 
- 		return nil
 
- 	})
 
- 	endTime := time.Now().Unix()
 
- 	assert.Error(err).IsNil()
 
- 	assert.Int64(endTime - startTime).AtLeast(0)
 
- }
 
- func TestRetryOnce(t *testing.T) {
 
- 	v2testing.Current(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)
 
- 	assert.Error(err).IsNil()
 
- 	assert.Int64(int64(duration / time.Millisecond)).AtLeast(900)
 
- }
 
- func TestRetryMultiple(t *testing.T) {
 
- 	v2testing.Current(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)
 
- 	assert.Error(err).IsNil()
 
- 	assert.Int64(int64(duration / time.Millisecond)).AtLeast(4900)
 
- }
 
- func TestRetryExhausted(t *testing.T) {
 
- 	v2testing.Current(t)
 
- 	startTime := time.Now()
 
- 	called := 0
 
- 	err := Timed(2, 1000).On(func() error {
 
- 		if called < 5 {
 
- 			called++
 
- 			return errorTestOnly
 
- 		}
 
- 		return nil
 
- 	})
 
- 	duration := time.Since(startTime)
 
- 	assert.Error(err).Equals(ErrorRetryFailed)
 
- 	assert.Int64(int64(duration / time.Millisecond)).AtLeast(1900)
 
- }
 
 
  |