-
Notifications
You must be signed in to change notification settings - Fork 211
/
Copy pathrace_test.go
48 lines (45 loc) · 1.08 KB
/
race_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Copyright 2016 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package rand
import (
"sync"
"testing"
)
// TestConcurrent exercises the rand API concurrently, triggering situations
// where the race detector is likely to detect issues.
func TestConcurrent(t *testing.T) {
const (
numRoutines = 10
numCycles = 10
)
var wg sync.WaitGroup
defer wg.Wait()
wg.Add(numRoutines)
for i := 0; i < numRoutines; i++ {
go func(i int) {
defer wg.Done()
buf := make([]byte, 997)
for j := 0; j < numCycles; j++ {
var seed uint64
seed += uint64(ExpFloat64())
seed += uint64(Float32())
seed += uint64(Float64())
seed += uint64(Intn(Int()))
seed += uint64(Int31n(Int31()))
seed += uint64(Int63n(Int63()))
seed += uint64(NormFloat64())
seed += uint64(Uint32())
seed += uint64(Uint64())
for _, p := range Perm(10) {
seed += uint64(p)
}
Read(buf)
for _, b := range buf {
seed += uint64(b)
}
Seed(uint64(i*j) * seed)
}
}(i)
}
}