From 157183170c85e2a3672be943c52c479d9e2d5fcd Mon Sep 17 00:00:00 2001 From: Travis Cline Date: Sat, 31 Aug 2024 16:53:26 -0700 Subject: [PATCH] Allow errors supplied to RecordError to supply values for semconv.ExceptionType --- sdk/trace/span.go | 7 +++++++ sdk/trace/trace_test.go | 13 +++++++++++++ 2 files changed, 20 insertions(+) diff --git a/sdk/trace/span.go b/sdk/trace/span.go index 4945f5083..88a92869d 100644 --- a/sdk/trace/span.go +++ b/sdk/trace/span.go @@ -469,7 +469,14 @@ func (s *recordingSpan) RecordError(err error, opts ...trace.EventOption) { s.addEvent(semconv.ExceptionEventName, opts...) } +type exceptionTyper interface { + ExceptionType() string +} + func typeStr(i interface{}) string { + if i, ok := i.(exceptionTyper); ok { + return i.ExceptionType() + } t := reflect.TypeOf(i) if t.PkgPath() == "" && t.Name() == "" { // Likely a builtin type. diff --git a/sdk/trace/trace_test.go b/sdk/trace/trace_test.go index 87247d1f1..38628b244 100644 --- a/sdk/trace/trace_test.go +++ b/sdk/trace/trace_test.go @@ -1189,6 +1189,14 @@ func TestCustomStartEndTime(t *testing.T) { } } +type errWithExceptionType struct { + error +} + +func (errWithExceptionType) ExceptionType() string { + return "CustomExceptionType" +} + func TestRecordError(t *testing.T) { scenarios := []struct { err error @@ -1205,6 +1213,11 @@ func TestRecordError(t *testing.T) { typ: "*errors.errorString", msg: "test error 2", }, + { + err: errWithExceptionType{errors.New("test error 3")}, + typ: "CustomExceptionType", + msg: "test error 3", + }, } for _, s := range scenarios {