go-zero/core/trace/message_test.go

77 lines
1.7 KiB
Go
Raw Normal View History

2023-02-12 20:32:56 +08:00
package trace
import (
"context"
"testing"
"github.com/stretchr/testify/assert"
"go.opentelemetry.io/otel"
2023-02-12 20:32:56 +08:00
"go.opentelemetry.io/otel/attribute"
"go.opentelemetry.io/otel/codes"
"go.opentelemetry.io/otel/trace"
"google.golang.org/protobuf/reflect/protoreflect"
"google.golang.org/protobuf/types/dynamicpb"
)
func TestMessageType_Event(t *testing.T) {
ctx, s := otel.Tracer(TraceName).Start(context.Background(), "test")
span := mockSpan{Span: s}
ctx = trace.ContextWithSpan(ctx, &span)
2023-02-12 20:32:56 +08:00
MessageReceived.Event(ctx, 1, "foo")
assert.Equal(t, messageEvent, span.name)
assert.NotEmpty(t, span.options)
}
func TestMessageType_EventProtoMessage(t *testing.T) {
var span mockSpan
var message mockMessage
ctx := trace.ContextWithSpan(context.Background(), &span)
MessageReceived.Event(ctx, 1, message)
assert.Equal(t, messageEvent, span.name)
assert.NotEmpty(t, span.options)
}
type mockSpan struct {
trace.Span
2023-02-12 20:32:56 +08:00
name string
options []trace.EventOption
}
2024-03-08 22:35:17 +08:00
func (m *mockSpan) End(_ ...trace.SpanEndOption) {
2023-02-12 20:32:56 +08:00
}
func (m *mockSpan) AddEvent(name string, options ...trace.EventOption) {
m.name = name
m.options = options
}
func (m *mockSpan) IsRecording() bool {
return false
}
2024-03-08 22:35:17 +08:00
func (m *mockSpan) RecordError(_ error, _ ...trace.EventOption) {
2023-02-12 20:32:56 +08:00
}
func (m *mockSpan) SpanContext() trace.SpanContext {
panic("implement me")
}
2024-03-08 22:35:17 +08:00
func (m *mockSpan) SetStatus(_ codes.Code, _ string) {
2023-02-12 20:32:56 +08:00
}
2024-03-08 22:35:17 +08:00
func (m *mockSpan) SetName(_ string) {
2023-02-12 20:32:56 +08:00
}
2024-03-08 22:35:17 +08:00
func (m *mockSpan) SetAttributes(_ ...attribute.KeyValue) {
2023-02-12 20:32:56 +08:00
}
func (m *mockSpan) TracerProvider() trace.TracerProvider {
return nil
}
type mockMessage struct{}
func (m mockMessage) ProtoReflect() protoreflect.Message {
return new(dynamicpb.Message)
}