| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 | package retry_testimport (	"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)}
 |