Skip to content

Commit 6432877

Browse files
committed
Add benchmarks for slogSink
1 parent f558531 commit 6432877

File tree

2 files changed

+150
-0
lines changed

2 files changed

+150
-0
lines changed

benchmark/benchmark_slog_test.go

+142
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,142 @@
1+
//go:build go1.21
2+
// +build go1.21
3+
4+
/*
5+
Copyright 2021 The logr Authors.
6+
7+
Licensed under the Apache License, Version 2.0 (the "License");
8+
you may not use this file except in compliance with the License.
9+
You may obtain a copy of the License at
10+
11+
http://www.apache.org/licenses/LICENSE-2.0
12+
13+
Unless required by applicable law or agreed to in writing, software
14+
distributed under the License is distributed on an "AS IS" BASIS,
15+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16+
See the License for the specific language governing permissions and
17+
limitations under the License.
18+
*/
19+
20+
package logr
21+
22+
import (
23+
"log/slog"
24+
"os"
25+
"testing"
26+
27+
"github.com/go-logr/logr"
28+
)
29+
30+
//
31+
// slogSink wrapper of discard
32+
//
33+
34+
func BenchmarkSlogSinkLogInfoOneArg(b *testing.B) {
35+
var log logr.Logger = logr.FromSlogHandler(logr.ToSlogHandler(logr.Discard()))
36+
doInfoOneArg(b, log)
37+
}
38+
39+
func BenchmarkSlogSinkLogInfoSeveralArgs(b *testing.B) {
40+
var log logr.Logger = logr.FromSlogHandler(logr.ToSlogHandler(logr.Discard()))
41+
doInfoSeveralArgs(b, log)
42+
}
43+
44+
func BenchmarkSlogSinkLogInfoWithValues(b *testing.B) {
45+
var log logr.Logger = logr.FromSlogHandler(logr.ToSlogHandler(logr.Discard()))
46+
doInfoWithValues(b, log)
47+
}
48+
49+
func BenchmarkSlogSinkLogV0Info(b *testing.B) {
50+
var log logr.Logger = logr.FromSlogHandler(logr.ToSlogHandler(logr.Discard()))
51+
doV0Info(b, log)
52+
}
53+
54+
func BenchmarkSlogSinkLogV9Info(b *testing.B) {
55+
var log logr.Logger = logr.FromSlogHandler(logr.ToSlogHandler(logr.Discard()))
56+
doV9Info(b, log)
57+
}
58+
59+
func BenchmarkSlogSinkLogError(b *testing.B) {
60+
var log logr.Logger = logr.FromSlogHandler(logr.ToSlogHandler(logr.Discard()))
61+
doError(b, log)
62+
}
63+
64+
func BenchmarkSlogSinkWithValues(b *testing.B) {
65+
var log logr.Logger = logr.FromSlogHandler(logr.ToSlogHandler(logr.Discard()))
66+
doWithValues(b, log)
67+
}
68+
69+
func BenchmarkSlogSinkWithName(b *testing.B) {
70+
var log logr.Logger = logr.FromSlogHandler(logr.ToSlogHandler(logr.Discard()))
71+
doWithName(b, log)
72+
}
73+
74+
//
75+
// slogSink wrapper of slog's JSONHandler, for comparison
76+
//
77+
78+
func makeSlogJSONLogger() logr.Logger {
79+
devnull, _ := os.Open("/dev/null")
80+
handler := slog.NewJSONHandler(devnull, nil)
81+
return logr.FromSlogHandler(handler)
82+
}
83+
84+
func BenchmarkSlogJSONLogInfoOneArg(b *testing.B) {
85+
var log logr.Logger = makeSlogJSONLogger()
86+
doInfoOneArg(b, log)
87+
}
88+
89+
func BenchmarkSlogJSONLogInfoSeveralArgs(b *testing.B) {
90+
var log logr.Logger = makeSlogJSONLogger()
91+
doInfoSeveralArgs(b, log)
92+
}
93+
94+
func BenchmarkSlogJSONLogInfoWithValues(b *testing.B) {
95+
var log logr.Logger = makeSlogJSONLogger()
96+
doInfoWithValues(b, log)
97+
}
98+
99+
func BenchmarkSlogJSONLogV0Info(b *testing.B) {
100+
var log logr.Logger = makeSlogJSONLogger()
101+
doV0Info(b, log)
102+
}
103+
104+
func BenchmarkSlogJSONLogV9Info(b *testing.B) {
105+
var log logr.Logger = makeSlogJSONLogger()
106+
doV9Info(b, log)
107+
}
108+
109+
func BenchmarkSlogJSONLogError(b *testing.B) {
110+
var log logr.Logger = makeSlogJSONLogger()
111+
doError(b, log)
112+
}
113+
114+
func BenchmarkSlogJSONLogWithValues(b *testing.B) {
115+
var log logr.Logger = makeSlogJSONLogger()
116+
doWithValues(b, log)
117+
}
118+
119+
func BenchmarkSlogJSONWithName(b *testing.B) {
120+
var log logr.Logger = makeSlogJSONLogger()
121+
doWithName(b, log)
122+
}
123+
124+
func BenchmarkSlogJSONWithCallDepth(b *testing.B) {
125+
var log logr.Logger = makeSlogJSONLogger()
126+
doWithCallDepth(b, log)
127+
}
128+
129+
func BenchmarkSlogJSONLogInfoStringerValue(b *testing.B) {
130+
var log logr.Logger = makeSlogJSONLogger()
131+
doStringerValue(b, log)
132+
}
133+
134+
func BenchmarkSlogJSONLogInfoErrorValue(b *testing.B) {
135+
var log logr.Logger = makeSlogJSONLogger()
136+
doErrorValue(b, log)
137+
}
138+
139+
func BenchmarkSlogJSONLogInfoMarshalerValue(b *testing.B) {
140+
var log logr.Logger = makeSlogJSONLogger()
141+
doMarshalerValue(b, log)
142+
}

benchmark/benchmark_test.go

+8
Original file line numberDiff line numberDiff line change
@@ -141,6 +141,10 @@ func doMarshalerValue(b *testing.B, log logr.Logger) {
141141
}
142142
}
143143

144+
//
145+
// discard
146+
//
147+
144148
func BenchmarkDiscardLogInfoOneArg(b *testing.B) {
145149
var log logr.Logger = logr.Discard()
146150
doInfoOneArg(b, log)
@@ -181,6 +185,10 @@ func BenchmarkDiscardWithName(b *testing.B) {
181185
doWithName(b, log)
182186
}
183187

188+
//
189+
// funcr
190+
//
191+
184192
func noopKV(_, _ string) {}
185193
func noopJSON(_ string) {}
186194

0 commit comments

Comments
 (0)