-
Notifications
You must be signed in to change notification settings - Fork 69
/
Copy pathraces_test.go
54 lines (48 loc) · 1.38 KB
/
races_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
//go:build race
// +build race
package eventhub
import (
"context"
"github.com/stretchr/testify/assert"
"sync"
"testing"
"time"
)
func (suite *eventHubSuite) TestConcurrency() {
tests := map[string]func(context.Context, *testing.T, *Hub, string){
"TestConcurrentSendWithRecover": testConcurrentSendWithRecover,
}
for name, testFunc := range tests {
setupTestTeardown := func(t *testing.T) {
hub, cleanup := suite.RandomHub()
defer cleanup()
partitionID := (*hub.PartitionIds)[0]
client, closer := suite.newClient(t, *hub.Name, HubWithPartitionedSender(partitionID))
defer closer()
ctx, cancel := context.WithTimeout(context.Background(), defaultTimeout)
defer cancel()
testFunc(ctx, t, client, partitionID)
}
suite.T().Run(name, setupTestTeardown)
}
}
func testConcurrentSendWithRecover(ctx context.Context, t *testing.T, client *Hub, _ string) {
var wg sync.WaitGroup
var err error
for i := 0; i < 100; i++ {
wg.Add(1)
go func() {
defer wg.Done()
// we don't check for errors here as the call to Recover()
// can cancel any in-flight calls to Send(). this is only
// an interesting test when race detection is enabled.
client.Send(ctx, NewEventFromString("Hello!"))
if inner := client.sender.Recover(ctx); inner != nil {
err = inner
}
}()
}
end, _ := ctx.Deadline()
waitUntil(t, &wg, time.Until(end))
assert.NoError(t, err)
}