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 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118
|
package dissolve
import (
"errors"
"sync"
"testing"
"time"
)
func TestDissolver(t *testing.T) {
d := New(4)
_ = d.Run()
defer func() { _ = d.Close() }()
ch := make(chan struct{})
numJobs := 1024
var wg sync.WaitGroup
errCh := make(chan error, 1)
wg.Add(numJobs)
go func() {
for i := 0; i < numJobs; i++ {
err := d.Submit(func() error {
defer wg.Done()
return nil
})
if err != nil {
errCh <- err
}
}
}()
go func() {
wg.Wait()
close(ch)
}()
select {
case <-ch:
case <-time.After(time.Second):
t.Fatal("timeout")
}
select {
case err := <-errCh:
t.Fatalf("Submit returned error: %v", err)
default:
}
}
func TestDissolverErrorHandling(t *testing.T) {
d := New(4)
_ = d.Run()
defer func() { _ = d.Close() }()
var numFails int
ch := make(chan struct{}, 1)
err := d.Submit(func() error {
if numFails < 10 {
// Fail Job several times.
numFails++
return errors.New("artificial error")
}
ch <- struct{}{}
return nil
})
if err != nil {
t.Fatalf("Submit returned error: %v", err)
}
select {
case <-ch:
case <-time.After(time.Second):
t.Fatal("timeout")
}
}
func TestDissolverClose(t *testing.T) {
d := New(4)
_ = d.Run()
_ = d.Close()
ch := make(chan struct{}, 1)
err := d.Submit(func() error {
ch <- struct{}{}
return nil
})
if err == nil {
t.Fatal("Submit should return error")
}
}
func BenchmarkSubmitAndProcess(b *testing.B) {
d := New(1)
_ = d.Run()
defer func() { _ = d.Close() }()
ch := make(chan struct{}, 1)
b.ResetTimer()
for i := 0; i < b.N; i++ {
_ = d.Submit(func() error {
ch <- struct{}{}
return nil
})
<-ch
}
b.ReportAllocs()
}
func BenchmarkSubmitAndProcessParallel(b *testing.B) {
d := New(128)
_ = d.Run()
defer func() { _ = d.Close() }()
ch := make(chan struct{}, 1)
b.SetParallelism(128)
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
_ = d.Submit(func() error {
ch <- struct{}{}
return nil
})
<-ch
}
})
b.ReportAllocs()
}
|