/
receive_cancellation.go
68 lines (50 loc) · 1.99 KB
/
receive_cancellation.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
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
package tests
import (
"context"
"errors"
"fmt"
"time"
"github.com/Azure/azure-sdk-for-go/sdk/messaging/azservicebus"
"github.com/Azure/azure-sdk-for-go/sdk/messaging/azservicebus/internal/stress/shared"
)
func ReceiveCancellation(remainingArgs []string) {
const rounds = 2000
sc := shared.MustCreateStressContext("FinitePeeks", nil)
defer sc.End()
queueName := fmt.Sprintf("finite-peeks-%s", sc.Nano)
sc.Start(queueName, map[string]string{
"Rounds": fmt.Sprintf("%d", rounds),
})
shared.MustCreateAutoDeletingQueue(sc, queueName, nil)
client, err := azservicebus.NewClientFromConnectionString(sc.ConnectionString, nil)
sc.PanicOnError("failed to create client", err)
for i := 0; i < rounds; i += 100 {
func() {
receiver, err := shared.NewTrackingReceiverForQueue(sc.TC, client, queueName, nil)
sc.PanicOnError("failed to create receiver", err)
defer receiver.Close(context.Background())
ctx, cancel := context.WithTimeout(context.Background(), time.Duration(i)*time.Millisecond)
defer cancel()
// from a cold receiver link
_, err = receiver.ReceiveMessages(ctx, 95, nil)
if !errors.Is(err, context.Canceled) && !errors.Is(err, context.DeadlineExceeded) {
sc.PanicOnError("failed to receive messages (1)", err)
}
shared.TrackMetric(sc.Context, sc.TC, shared.MetricStressSuccessfulCancels, float64(1), map[string]string{
"Type": "cold",
})
ctx, cancel = context.WithTimeout(context.Background(), time.Duration(i)*time.Millisecond)
defer cancel()
// and one more time, now that the link has been warmed up
_, err = receiver.ReceiveMessages(ctx, 95, nil)
if !errors.Is(err, context.Canceled) && !errors.Is(err, context.DeadlineExceeded) {
sc.PanicOnError("failed to receive messages (2)", err)
}
shared.TrackMetric(sc.Context, sc.TC, shared.MetricStressSuccessfulCancels, float64(1), map[string]string{
"Type": "warm",
})
}()
}
}