forked from opentracing/basictracer-go
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathconcurrency_test.go
More file actions
94 lines (88 loc) · 1.99 KB
/
concurrency_test.go
File metadata and controls
94 lines (88 loc) · 1.99 KB
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
package basictracer
import (
"sync"
"testing"
opentracing "github.com/opentracing/opentracing-go"
)
const op = "test"
func TestDebugAssertSingleGoroutine(t *testing.T) {
opts := DefaultOptions()
opts.Recorder = NewInMemoryRecorder()
opts.DebugAssertSingleGoroutine = true
tracer := NewWithOptions(opts)
sp := tracer.StartSpan(op)
sp.LogEvent("something on my goroutine")
wait := make(chan struct{})
var panicked bool
go func() {
defer func() {
if r := recover(); r != nil {
_, panicked = r.(*errAssertionFailed)
}
close(wait)
}()
sp.LogEvent("something on your goroutine")
}()
<-wait
if !panicked {
t.Fatal("expected a panic")
}
}
func TestDebugAssertUseAfterFinish(t *testing.T) {
opts := DefaultOptions()
opts.Recorder = NewInMemoryRecorder()
opts.DebugAssertUseAfterFinish = true
tracer := NewWithOptions(opts)
for _, double := range []bool{false, true} {
sp := tracer.StartSpan(op)
if double {
sp.Finish()
}
var panicked bool
func() {
defer func() {
r := recover()
_, panicked = r.(*errAssertionFailed)
if !panicked && r != nil {
panic(r)
}
spImpl := sp.(*spanImpl)
// The panic should leave the Mutex unlocked.
spImpl.Mutex.Lock()
spImpl.Mutex.Unlock()
}()
sp.Finish()
}()
if panicked != double {
t.Errorf("finished double = %t, but panicked = %t", double, panicked)
}
}
}
func TestConcurrentUsage(t *testing.T) {
opts := DefaultOptions()
var cr CountingRecorder
opts.Recorder = &cr
opts.DebugAssertSingleGoroutine = true
tracer := NewWithOptions(opts)
var wg sync.WaitGroup
const num = 100
wg.Add(num)
for i := 0; i < num; i++ {
go func() {
defer wg.Done()
for j := 0; j < num; j++ {
sp := tracer.StartSpan(op)
sp.LogEvent("test event")
sp.SetTag("foo", "bar")
sp.SetBaggageItem("boo", "far")
sp.SetOperationName("x")
csp := tracer.StartSpanWithOptions(opentracing.StartSpanOptions{
Parent: sp,
})
csp.Finish()
defer sp.Finish()
}
}()
}
wg.Wait()
}