File: benchmark_test.go

package info (click to toggle)
golang-github-go-kit-log 0.2.1-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 308 kB
  • sloc: makefile: 2
file content (72 lines) | stat: -rw-r--r-- 1,669 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
package level_test

import (
	"io/ioutil"
	"testing"

	"github.com/go-kit/log"
	"github.com/go-kit/log/level"
)

func Benchmark(b *testing.B) {
	contexts := []struct {
		name    string
		context func(log.Logger) log.Logger
	}{
		{"NoContext", func(l log.Logger) log.Logger {
			return l
		}},
		{"TimeContext", func(l log.Logger) log.Logger {
			return log.With(l, "time", log.DefaultTimestampUTC)
		}},
		{"CallerContext", func(l log.Logger) log.Logger {
			return log.With(l, "caller", log.DefaultCaller)
		}},
		{"TimeCallerReqIDContext", func(l log.Logger) log.Logger {
			return log.With(l, "time", log.DefaultTimestampUTC, "caller", log.DefaultCaller, "reqID", 29)
		}},
	}

	loggers := []struct {
		name   string
		logger log.Logger
	}{
		{"Nop", log.NewNopLogger()},
		{"Logfmt", log.NewLogfmtLogger(ioutil.Discard)},
		{"JSON", log.NewJSONLogger(ioutil.Discard)},
	}

	filters := []struct {
		name   string
		filter func(log.Logger) log.Logger
	}{
		{"Baseline", func(l log.Logger) log.Logger {
			return l
		}},
		{"DisallowedLevel", func(l log.Logger) log.Logger {
			return level.NewFilter(l, level.AllowInfo())
		}},
		{"AllowedLevel", func(l log.Logger) log.Logger {
			return level.NewFilter(l, level.AllowAll())
		}},
	}

	for _, c := range contexts {
		b.Run(c.name, func(b *testing.B) {
			for _, f := range filters {
				b.Run(f.name, func(b *testing.B) {
					for _, l := range loggers {
						b.Run(l.name, func(b *testing.B) {
							logger := c.context(f.filter(l.logger))
							b.ResetTimer()
							b.ReportAllocs()
							for i := 0; i < b.N; i++ {
								level.Debug(logger).Log("foo", "bar")
							}
						})
					}
				})
			}
		})
	}
}