p2p/discover: use separate rand.Source instances in tests
rand.Source isn't safe for concurrent use.
This commit is contained in:
		@@ -13,11 +13,6 @@ import (
 | 
				
			|||||||
	"github.com/ethereum/go-ethereum/crypto"
 | 
						"github.com/ethereum/go-ethereum/crypto"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
var (
 | 
					 | 
				
			||||||
	quickrand = rand.New(rand.NewSource(time.Now().Unix()))
 | 
					 | 
				
			||||||
	quickcfg  = &quick.Config{MaxCount: 5000, Rand: quickrand}
 | 
					 | 
				
			||||||
)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
var parseNodeTests = []struct {
 | 
					var parseNodeTests = []struct {
 | 
				
			||||||
	rawurl     string
 | 
						rawurl     string
 | 
				
			||||||
	wantError  string
 | 
						wantError  string
 | 
				
			||||||
@@ -176,7 +171,7 @@ func TestNodeID_distcmp(t *testing.T) {
 | 
				
			|||||||
		bbig := new(big.Int).SetBytes(b[:])
 | 
							bbig := new(big.Int).SetBytes(b[:])
 | 
				
			||||||
		return new(big.Int).Xor(tbig, abig).Cmp(new(big.Int).Xor(tbig, bbig))
 | 
							return new(big.Int).Xor(tbig, abig).Cmp(new(big.Int).Xor(tbig, bbig))
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if err := quick.CheckEqual(distcmp, distcmpBig, quickcfg); err != nil {
 | 
						if err := quick.CheckEqual(distcmp, distcmpBig, quickcfg()); err != nil {
 | 
				
			||||||
		t.Error(err)
 | 
							t.Error(err)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -195,7 +190,7 @@ func TestNodeID_logdist(t *testing.T) {
 | 
				
			|||||||
		abig, bbig := new(big.Int).SetBytes(a[:]), new(big.Int).SetBytes(b[:])
 | 
							abig, bbig := new(big.Int).SetBytes(a[:]), new(big.Int).SetBytes(b[:])
 | 
				
			||||||
		return new(big.Int).Xor(abig, bbig).BitLen()
 | 
							return new(big.Int).Xor(abig, bbig).BitLen()
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if err := quick.CheckEqual(logdist, logdistBig, quickcfg); err != nil {
 | 
						if err := quick.CheckEqual(logdist, logdistBig, quickcfg()); err != nil {
 | 
				
			||||||
		t.Error(err)
 | 
							t.Error(err)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -211,9 +206,10 @@ func TestNodeID_logdistEqual(t *testing.T) {
 | 
				
			|||||||
func TestNodeID_hashAtDistance(t *testing.T) {
 | 
					func TestNodeID_hashAtDistance(t *testing.T) {
 | 
				
			||||||
	// we don't use quick.Check here because its output isn't
 | 
						// we don't use quick.Check here because its output isn't
 | 
				
			||||||
	// very helpful when the test fails.
 | 
						// very helpful when the test fails.
 | 
				
			||||||
	for i := 0; i < quickcfg.MaxCount; i++ {
 | 
						cfg := quickcfg()
 | 
				
			||||||
		a := gen(common.Hash{}, quickrand).(common.Hash)
 | 
						for i := 0; i < cfg.MaxCount; i++ {
 | 
				
			||||||
		dist := quickrand.Intn(len(common.Hash{}) * 8)
 | 
							a := gen(common.Hash{}, cfg.Rand).(common.Hash)
 | 
				
			||||||
 | 
							dist := cfg.Rand.Intn(len(common.Hash{}) * 8)
 | 
				
			||||||
		result := hashAtDistance(a, dist)
 | 
							result := hashAtDistance(a, dist)
 | 
				
			||||||
		actualdist := logdist(result, a)
 | 
							actualdist := logdist(result, a)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -225,7 +221,14 @@ func TestNodeID_hashAtDistance(t *testing.T) {
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// TODO: this can be dropped when we require Go >= 1.5
 | 
					func quickcfg() *quick.Config {
 | 
				
			||||||
 | 
						return &quick.Config{
 | 
				
			||||||
 | 
							MaxCount: 5000,
 | 
				
			||||||
 | 
							Rand:     rand.New(rand.NewSource(time.Now().Unix())),
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// TODO: The Generate method can be dropped when we require Go >= 1.5
 | 
				
			||||||
// because testing/quick learned to generate arrays in 1.5.
 | 
					// because testing/quick learned to generate arrays in 1.5.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (NodeID) Generate(rand *rand.Rand, size int) reflect.Value {
 | 
					func (NodeID) Generate(rand *rand.Rand, size int) reflect.Value {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -9,6 +9,7 @@ import (
 | 
				
			|||||||
	"reflect"
 | 
						"reflect"
 | 
				
			||||||
	"testing"
 | 
						"testing"
 | 
				
			||||||
	"testing/quick"
 | 
						"testing/quick"
 | 
				
			||||||
 | 
						"time"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	"github.com/ethereum/go-ethereum/common"
 | 
						"github.com/ethereum/go-ethereum/common"
 | 
				
			||||||
	"github.com/ethereum/go-ethereum/crypto"
 | 
						"github.com/ethereum/go-ethereum/crypto"
 | 
				
			||||||
@@ -74,7 +75,7 @@ func TestBucket_bumpNoDuplicates(t *testing.T) {
 | 
				
			|||||||
	t.Parallel()
 | 
						t.Parallel()
 | 
				
			||||||
	cfg := &quick.Config{
 | 
						cfg := &quick.Config{
 | 
				
			||||||
		MaxCount: 1000,
 | 
							MaxCount: 1000,
 | 
				
			||||||
		Rand:     quickrand,
 | 
							Rand:     rand.New(rand.NewSource(time.Now().Unix())),
 | 
				
			||||||
		Values: func(args []reflect.Value, rand *rand.Rand) {
 | 
							Values: func(args []reflect.Value, rand *rand.Rand) {
 | 
				
			||||||
			// generate a random list of nodes. this will be the content of the bucket.
 | 
								// generate a random list of nodes. this will be the content of the bucket.
 | 
				
			||||||
			n := rand.Intn(bucketSize-1) + 1
 | 
								n := rand.Intn(bucketSize-1) + 1
 | 
				
			||||||
@@ -205,7 +206,7 @@ func TestTable_closest(t *testing.T) {
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
		return true
 | 
							return true
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	if err := quick.Check(test, quickcfg); err != nil {
 | 
						if err := quick.Check(test, quickcfg()); err != nil {
 | 
				
			||||||
		t.Error(err)
 | 
							t.Error(err)
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@@ -213,7 +214,7 @@ func TestTable_closest(t *testing.T) {
 | 
				
			|||||||
func TestTable_ReadRandomNodesGetAll(t *testing.T) {
 | 
					func TestTable_ReadRandomNodesGetAll(t *testing.T) {
 | 
				
			||||||
	cfg := &quick.Config{
 | 
						cfg := &quick.Config{
 | 
				
			||||||
		MaxCount: 200,
 | 
							MaxCount: 200,
 | 
				
			||||||
		Rand:     quickrand,
 | 
							Rand:     rand.New(rand.NewSource(time.Now().Unix())),
 | 
				
			||||||
		Values: func(args []reflect.Value, rand *rand.Rand) {
 | 
							Values: func(args []reflect.Value, rand *rand.Rand) {
 | 
				
			||||||
			args[0] = reflect.ValueOf(make([]*Node, rand.Intn(1000)))
 | 
								args[0] = reflect.ValueOf(make([]*Node, rand.Intn(1000)))
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
@@ -221,7 +222,7 @@ func TestTable_ReadRandomNodesGetAll(t *testing.T) {
 | 
				
			|||||||
	test := func(buf []*Node) bool {
 | 
						test := func(buf []*Node) bool {
 | 
				
			||||||
		tab := newTable(nil, NodeID{}, &net.UDPAddr{}, "")
 | 
							tab := newTable(nil, NodeID{}, &net.UDPAddr{}, "")
 | 
				
			||||||
		for i := 0; i < len(buf); i++ {
 | 
							for i := 0; i < len(buf); i++ {
 | 
				
			||||||
			ld := quickrand.Intn(len(tab.buckets))
 | 
								ld := cfg.Rand.Intn(len(tab.buckets))
 | 
				
			||||||
			tab.add([]*Node{nodeAtDistance(tab.self.sha, ld)})
 | 
								tab.add([]*Node{nodeAtDistance(tab.self.sha, ld)})
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		gotN := tab.ReadRandomNodes(buf)
 | 
							gotN := tab.ReadRandomNodes(buf)
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user