mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2025-01-12 02:28:07 +02:00
116 lines
3.2 KiB
Go
116 lines
3.2 KiB
Go
|
// Copyright The OpenTelemetry Authors
|
||
|
//
|
||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||
|
// you may not use this file except in compliance with the License.
|
||
|
// You may obtain a copy of the License at
|
||
|
//
|
||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||
|
//
|
||
|
// Unless required by applicable law or agreed to in writing, software
|
||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
|
// See the License for the specific language governing permissions and
|
||
|
// limitations under the License.
|
||
|
|
||
|
package jaeger
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"fmt"
|
||
|
"testing"
|
||
|
"time"
|
||
|
|
||
|
"go.opentelemetry.io/otel/sdk/instrumentation"
|
||
|
tracesdk "go.opentelemetry.io/otel/sdk/trace"
|
||
|
"go.opentelemetry.io/otel/sdk/trace/tracetest"
|
||
|
"go.opentelemetry.io/otel/trace"
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
traceID trace.TraceID
|
||
|
spanID trace.SpanID
|
||
|
spanContext trace.SpanContext
|
||
|
|
||
|
instrLibName = "benchmark.tests"
|
||
|
)
|
||
|
|
||
|
func init() {
|
||
|
var err error
|
||
|
traceID, err = trace.TraceIDFromHex("0102030405060708090a0b0c0d0e0f10")
|
||
|
if err != nil {
|
||
|
panic(err)
|
||
|
}
|
||
|
spanID, err = trace.SpanIDFromHex("0102030405060708")
|
||
|
if err != nil {
|
||
|
panic(err)
|
||
|
}
|
||
|
spanContext = trace.NewSpanContext(trace.SpanContextConfig{
|
||
|
TraceID: traceID,
|
||
|
SpanID: spanID,
|
||
|
})
|
||
|
}
|
||
|
|
||
|
func spans(n int) []tracesdk.ReadOnlySpan {
|
||
|
now := time.Now()
|
||
|
s := make(tracetest.SpanStubs, n)
|
||
|
for i := 0; i < n; i++ {
|
||
|
name := fmt.Sprintf("span %d", i)
|
||
|
s[i] = tracetest.SpanStub{
|
||
|
SpanContext: spanContext,
|
||
|
Name: name,
|
||
|
StartTime: now,
|
||
|
EndTime: now,
|
||
|
SpanKind: trace.SpanKindClient,
|
||
|
InstrumentationLibrary: instrumentation.Library{
|
||
|
Name: instrLibName,
|
||
|
},
|
||
|
}
|
||
|
}
|
||
|
return s.Snapshots()
|
||
|
}
|
||
|
|
||
|
func benchmarkExportSpans(b *testing.B, o EndpointOption, i int) {
|
||
|
ctx := context.Background()
|
||
|
s := spans(i)
|
||
|
exp, err := New(o)
|
||
|
if err != nil {
|
||
|
b.Fatal(err)
|
||
|
}
|
||
|
|
||
|
b.ReportAllocs()
|
||
|
b.ResetTimer()
|
||
|
|
||
|
for n := 0; n < b.N; n++ {
|
||
|
if err := exp.ExportSpans(ctx, s); err != nil {
|
||
|
b.Error(err)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func benchmarkCollector(b *testing.B, i int) {
|
||
|
benchmarkExportSpans(b, withTestCollectorEndpoint(), i)
|
||
|
}
|
||
|
|
||
|
func benchmarkAgent(b *testing.B, i int) {
|
||
|
benchmarkExportSpans(b, WithAgentEndpoint(), i)
|
||
|
}
|
||
|
|
||
|
func BenchmarkCollectorExportSpans1(b *testing.B) { benchmarkCollector(b, 1) }
|
||
|
func BenchmarkCollectorExportSpans10(b *testing.B) { benchmarkCollector(b, 10) }
|
||
|
func BenchmarkCollectorExportSpans100(b *testing.B) { benchmarkCollector(b, 100) }
|
||
|
func BenchmarkCollectorExportSpans1000(b *testing.B) { benchmarkCollector(b, 1000) }
|
||
|
func BenchmarkCollectorExportSpans10000(b *testing.B) { benchmarkCollector(b, 10000) }
|
||
|
func BenchmarkAgentExportSpans1(b *testing.B) { benchmarkAgent(b, 1) }
|
||
|
func BenchmarkAgentExportSpans10(b *testing.B) { benchmarkAgent(b, 10) }
|
||
|
func BenchmarkAgentExportSpans100(b *testing.B) { benchmarkAgent(b, 100) }
|
||
|
|
||
|
/*
|
||
|
* BUG: These tests are not possible currently because the thrift payload size
|
||
|
* does not fit in a UDP packet with the default size (65000) and will return
|
||
|
* an error.
|
||
|
|
||
|
func BenchmarkAgentExportSpans1000(b *testing.B) { benchmarkAgent(b, 1000) }
|
||
|
func BenchmarkAgentExportSpans10000(b *testing.B) { benchmarkAgent(b, 10000) }
|
||
|
|
||
|
*/
|