1
0
mirror of https://github.com/open-telemetry/opentelemetry-go.git synced 2026-06-03 18:35:08 +02:00
Files
opentelemetry-go/exporters/prometheus/benchmark_test.go
T

44 lines
1.2 KiB
Go
Raw Normal View History

2022-09-22 17:02:13 +02:00
// Copyright The OpenTelemetry Authors
2024-02-29 07:05:28 +01:00
// SPDX-License-Identifier: Apache-2.0
2022-09-22 17:02:13 +02:00
package prometheus
import (
"context"
"fmt"
"testing"
"github.com/prometheus/client_golang/prometheus"
"github.com/stretchr/testify/require"
"go.opentelemetry.io/otel/sdk/metric"
)
func benchmarkCollect(b *testing.B, n int) {
ctx := context.Background()
registry := prometheus.NewRegistry()
2022-10-14 09:22:43 -05:00
exporter, err := New(WithRegisterer(registry))
2022-09-22 17:02:13 +02:00
require.NoError(b, err)
2022-10-14 09:22:43 -05:00
provider := metric.NewMeterProvider(metric.WithReader(exporter))
meter := provider.Meter("testmeter")
2022-09-22 17:02:13 +02:00
for i := 0; i < n; i++ {
counter, err := meter.Float64Counter(fmt.Sprintf("foo_%d", i))
2022-09-22 17:02:13 +02:00
require.NoError(b, err)
counter.Add(ctx, float64(i))
}
b.ReportAllocs()
b.ResetTimer()
for i := 0; i < b.N; i++ {
_, err := registry.Gather()
require.NoError(b, err)
}
}
func BenchmarkCollect1(b *testing.B) { benchmarkCollect(b, 1) }
func BenchmarkCollect10(b *testing.B) { benchmarkCollect(b, 10) }
func BenchmarkCollect100(b *testing.B) { benchmarkCollect(b, 100) }
func BenchmarkCollect1000(b *testing.B) { benchmarkCollect(b, 1000) }
func BenchmarkCollect10000(b *testing.B) { benchmarkCollect(b, 10000) }