-
Notifications
You must be signed in to change notification settings - Fork 101
/
grpool_test.go
103 lines (79 loc) · 1.78 KB
/
grpool_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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
package grpool
import (
"io/ioutil"
"log"
"runtime"
"sync/atomic"
"testing"
"github.com/stretchr/testify/assert"
)
func init() {
println("using MAXPROC")
numCPUs := runtime.NumCPU()
runtime.GOMAXPROCS(numCPUs)
}
func TestNewWorker(t *testing.T) {
pool := make(chan *worker)
worker := newWorker(pool)
worker.start()
assert.NotNil(t, worker)
worker = <-pool
assert.NotNil(t, worker, "Worker should register itself to the pool")
called := false
done := make(chan bool)
job := func() {
called = true
done <- true
}
worker.jobChannel <- job
<-done
assert.Equal(t, true, called)
}
func TestNewPool(t *testing.T) {
pool := NewPool(1000, 10000)
defer pool.Release()
iterations := 1000000
pool.WaitCount(iterations)
var counter uint64 = 0
for i := 0; i < iterations; i++ {
arg := uint64(1)
job := func() {
defer pool.JobDone()
atomic.AddUint64(&counter, arg)
assert.Equal(t, uint64(1), arg)
}
pool.JobQueue <- job
}
pool.WaitAll()
counterFinal := atomic.LoadUint64(&counter)
assert.Equal(t, uint64(iterations), counterFinal)
}
func TestRelease(t *testing.T) {
grNum := runtime.NumGoroutine()
pool := NewPool(5, 10)
defer func() {
pool.Release()
// give some time for all goroutines to quit
assert.Equal(t, grNum, runtime.NumGoroutine(), "All goroutines should be released after Release() call")
}()
pool.WaitCount(1000)
for i := 0; i < 1000; i++ {
job := func() {
defer pool.JobDone()
}
pool.JobQueue <- job
}
pool.WaitAll()
}
func BenchmarkPool(b *testing.B) {
// Testing with just 1 goroutine
// to benchmark the non-parallel part of the code
pool := NewPool(1, 10)
defer pool.Release()
log.SetOutput(ioutil.Discard)
for n := 0; n < b.N; n++ {
pool.JobQueue <- func() {
log.Printf("I am worker! Number %d\n", n)
}
}
}