From a3ecacfe0d8ae006b0605866927029c50395f9f4 Mon Sep 17 00:00:00 2001 From: Cheng-Zhen Yang Date: Sun, 24 Nov 2024 19:52:40 +1100 Subject: [PATCH] otellogr: Add benchmarks --- bridges/otellogr/logsink_test.go | 89 ++++++++++++++++++++++++++++++++ 1 file changed, 89 insertions(+) diff --git a/bridges/otellogr/logsink_test.go b/bridges/otellogr/logsink_test.go index 78d3bf491c4..e904fef00bf 100644 --- a/bridges/otellogr/logsink_test.go +++ b/bridges/otellogr/logsink_test.go @@ -462,3 +462,92 @@ func TestConvertKVs(t *testing.T) { }) } } + +func BenchmarkLogSink(b *testing.B) { + message := "body" + keyValues := []any{ + "string", "hello", + "int", 42, + "float", 3.14, + "bool", false, + } + err := errors.New("error") + + b.Run("Info", func(b *testing.B) { + logSinks := make([]logr.LogSink, b.N) + for i := range logSinks { + logSinks[i] = NewLogSink("") + } + + b.ReportAllocs() + b.ResetTimer() + for n := 0; n < b.N; n++ { + logSinks[n].Info(0, message, keyValues...) + } + }) + + b.Run("Error", func(b *testing.B) { + logSinks := make([]logr.LogSink, b.N) + for i := range logSinks { + logSinks[i] = NewLogSink("") + } + + b.ReportAllocs() + b.ResetTimer() + for n := 0; n < b.N; n++ { + logSinks[n].Error(err, message, keyValues...) + } + }) + + b.Run("WithValues", func(b *testing.B) { + logSinks := make([]logr.LogSink, b.N) + for i := range logSinks { + logSinks[i] = NewLogSink("") + } + + b.ReportAllocs() + b.ResetTimer() + for n := 0; n < b.N; n++ { + logSinks[n].WithValues(keyValues...) + } + }) + + b.Run("WithName", func(b *testing.B) { + logSinks := make([]logr.LogSink, b.N) + for i := range logSinks { + logSinks[i] = NewLogSink("") + } + + b.ReportAllocs() + b.ResetTimer() + for n := 0; n < b.N; n++ { + logSinks[n].WithName("name") + } + }) + + b.Run("WithName.WithValues", func(b *testing.B) { + logSinks := make([]logr.LogSink, b.N) + for i := range logSinks { + logSinks[i] = NewLogSink("") + } + + b.ReportAllocs() + b.ResetTimer() + for n := 0; n < b.N; n++ { + logSinks[n].WithName("name").WithValues(keyValues...) + } + }) + + b.Run("(WithName.WithValues).Info", func(b *testing.B) { + logSinks := make([]logr.LogSink, b.N) + for i := range logSinks { + logSinks[i] = NewLogSink("").WithName("name").WithValues(keyValues...) + } + + b.ReportAllocs() + b.ResetTimer() + for n := 0; n < b.N; n++ { + logSinks[n].Info(0, message) + } + }) +}