mirror of
https://github.com/pomerium/pomerium.git
synced 2025-06-24 21:48:23 +02:00
new tracing system
This commit is contained in:
parent
b87d940d11
commit
a6f43f3c3c
127 changed files with 7509 additions and 1454 deletions
71
internal/telemetry/trace/trace_export_test.go
Normal file
71
internal/telemetry/trace/trace_export_test.go
Normal file
|
@ -0,0 +1,71 @@
|
|||
package trace
|
||||
|
||||
import (
|
||||
"cmp"
|
||||
"io"
|
||||
"slices"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
oteltrace "go.opentelemetry.io/otel/trace"
|
||||
)
|
||||
|
||||
var (
|
||||
NewSpanObserver = newSpanObserver
|
||||
NewSpanTracker = newSpanTracker
|
||||
)
|
||||
|
||||
type XStackTraceProcessor = stackTraceProcessor
|
||||
|
||||
func (obs *spanObserver) XWait() {
|
||||
obs.wait(nil, 5*time.Second)
|
||||
}
|
||||
|
||||
func (obs *spanObserver) XUnobservedIDs() []oteltrace.SpanID {
|
||||
obs.cond.L.Lock()
|
||||
defer obs.cond.L.Unlock()
|
||||
ids := []oteltrace.SpanID{}
|
||||
for k, v := range obs.referencedIDs {
|
||||
if v.IsValid() {
|
||||
ids = append(ids, k)
|
||||
}
|
||||
}
|
||||
slices.SortFunc(ids, func(a, b oteltrace.SpanID) int {
|
||||
return cmp.Compare(a.String(), b.String())
|
||||
})
|
||||
return ids
|
||||
}
|
||||
|
||||
func (obs *spanObserver) XObservedIDs() []oteltrace.SpanID {
|
||||
obs.cond.L.Lock()
|
||||
defer obs.cond.L.Unlock()
|
||||
ids := []oteltrace.SpanID{}
|
||||
for k, v := range obs.referencedIDs {
|
||||
if !v.IsValid() {
|
||||
ids = append(ids, k)
|
||||
}
|
||||
}
|
||||
slices.SortFunc(ids, func(a, b oteltrace.SpanID) int {
|
||||
return cmp.Compare(a.String(), b.String())
|
||||
})
|
||||
return ids
|
||||
}
|
||||
|
||||
func (t *spanTracker) XInflightSpans() []oteltrace.SpanID {
|
||||
ids := []oteltrace.SpanID{}
|
||||
t.inflightSpans.Range(func(key, _ any) bool {
|
||||
ids = append(ids, key.(oteltrace.SpanID))
|
||||
return true
|
||||
})
|
||||
slices.SortFunc(ids, func(a, b oteltrace.SpanID) int {
|
||||
return cmp.Compare(a.String(), b.String())
|
||||
})
|
||||
return ids
|
||||
}
|
||||
|
||||
func SetDebugMessageWriterForTest(t testing.TB, w io.Writer) {
|
||||
debugMessageWriter = w
|
||||
t.Cleanup(func() {
|
||||
debugMessageWriter = nil
|
||||
})
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue