2020-08-23 22:33:20 +08:00
|
|
|
package clientinterceptors
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"testing"
|
2021-11-01 15:04:38 +08:00
|
|
|
"time"
|
2020-08-23 22:33:20 +08:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestDurationInterceptor(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
err error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "nil",
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "with error",
|
|
|
|
err: errors.New("mock"),
|
|
|
|
},
|
|
|
|
}
|
2023-03-10 21:56:19 +08:00
|
|
|
|
|
|
|
for _, test := range tests {
|
|
|
|
t.Run(test.name, func(t *testing.T) {
|
|
|
|
cc := new(grpc.ClientConn)
|
|
|
|
err := DurationInterceptor(context.Background(), "/foo", nil, nil, cc,
|
|
|
|
func(ctx context.Context, method string, req, reply any, cc *grpc.ClientConn,
|
|
|
|
opts ...grpc.CallOption) error {
|
|
|
|
return test.err
|
|
|
|
})
|
|
|
|
assert.Equal(t, test.err, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
DontLogContentForMethod("/foo")
|
|
|
|
t.Cleanup(func() {
|
|
|
|
notLoggingContentMethods.Delete("/foo")
|
|
|
|
})
|
|
|
|
|
|
|
|
for _, test := range tests {
|
|
|
|
t.Run(test.name, func(t *testing.T) {
|
|
|
|
cc := new(grpc.ClientConn)
|
|
|
|
err := DurationInterceptor(context.Background(), "/foo", nil, nil, cc,
|
|
|
|
func(ctx context.Context, method string, req, reply any, cc *grpc.ClientConn,
|
|
|
|
opts ...grpc.CallOption) error {
|
|
|
|
return test.err
|
|
|
|
})
|
|
|
|
assert.Equal(t, test.err, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDurationInterceptorWithSlowThreshold(t *testing.T) {
|
|
|
|
SetSlowThreshold(time.Microsecond)
|
|
|
|
t.Cleanup(func() {
|
|
|
|
SetSlowThreshold(defaultSlowThreshold)
|
|
|
|
})
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
err error
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "nil",
|
|
|
|
err: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "with error",
|
|
|
|
err: errors.New("mock"),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range tests {
|
|
|
|
t.Run(test.name, func(t *testing.T) {
|
|
|
|
cc := new(grpc.ClientConn)
|
|
|
|
err := DurationInterceptor(context.Background(), "/foo", nil, nil, cc,
|
|
|
|
func(ctx context.Context, method string, req, reply any, cc *grpc.ClientConn,
|
|
|
|
opts ...grpc.CallOption) error {
|
|
|
|
time.Sleep(time.Millisecond * 10)
|
|
|
|
return test.err
|
|
|
|
})
|
|
|
|
assert.Equal(t, test.err, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-12-04 00:25:52 +08:00
|
|
|
DontLogContentForMethod("/foo")
|
2023-03-10 21:56:19 +08:00
|
|
|
t.Cleanup(func() {
|
|
|
|
notLoggingContentMethods.Delete("/foo")
|
|
|
|
})
|
|
|
|
|
2020-08-23 22:33:20 +08:00
|
|
|
for _, test := range tests {
|
|
|
|
t.Run(test.name, func(t *testing.T) {
|
|
|
|
cc := new(grpc.ClientConn)
|
|
|
|
err := DurationInterceptor(context.Background(), "/foo", nil, nil, cc,
|
2023-01-24 16:32:02 +08:00
|
|
|
func(ctx context.Context, method string, req, reply any, cc *grpc.ClientConn,
|
2020-08-23 22:33:20 +08:00
|
|
|
opts ...grpc.CallOption) error {
|
2023-03-10 21:56:19 +08:00
|
|
|
time.Sleep(time.Millisecond * 10)
|
2020-08-23 22:33:20 +08:00
|
|
|
return test.err
|
|
|
|
})
|
|
|
|
assert.Equal(t, test.err, err)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
2021-11-01 15:04:38 +08:00
|
|
|
|
|
|
|
func TestSetSlowThreshold(t *testing.T) {
|
|
|
|
assert.Equal(t, defaultSlowThreshold, slowThreshold.Load())
|
|
|
|
SetSlowThreshold(time.Second)
|
|
|
|
assert.Equal(t, time.Second, slowThreshold.Load())
|
|
|
|
}
|