forked from phachon/go-logger
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbenchmark_test.go
97 lines (88 loc) · 2.26 KB
/
benchmark_test.go
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
package go_logger
import (
"testing"
)
// go test -run=benchmark -cpu=1,2,4 -benchmem -benchtime=3s -bench="ConsoleText"
func BenchmarkLoggerConsoleText(b *testing.B) {
logger := NewLogger()
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
logger.Info("benchmark logger message")
}
})
}
// go test -run=benchmark -cpu=1,2,4 -benchmem -benchtime=3s -bench="ConsoleAsyncText"
func BenchmarkLoggerConsoleAsyncText(b *testing.B) {
logger := NewLogger()
logger.SetAsync()
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
logger.Info("benchmark logger message")
}
})
logger.Flush()
}
// go test -run=benchmark -cpu=1,2,4 -benchmem -benchtime=3s -bench="ConsoleJson"
func BenchmarkLoggerConsoleJson(b *testing.B) {
logger := NewLogger()
logger.Detach("console")
logger.Attach("console", LOGGER_LEVEL_DEBUG, &ConsoleConfig{
JsonFormat: true,
})
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
logger.Info("benchmark logger message")
}
})
}
// go test -run=benchmark -cpu=1,2,4 -benchmem -benchtime=3s -bench="FileText"
func BenchmarkLoggerFileText(b *testing.B) {
logger := NewLogger()
logger.Detach("console")
logger.Attach("file", LOGGER_LEVEL_DEBUG, &FileConfig{
Filename: "./test.log",
DateSlice: "d",
})
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
logger.Info("benchmark logger message")
}
})
}
// go test -run=benchmark -cpu=1,2,4 -benchmem -benchtime=3s -bench="AsyncText"
func BenchmarkLoggerFileAsyncText(b *testing.B) {
logger := NewLogger()
logger.Detach("console")
logger.Attach("file", LOGGER_LEVEL_DEBUG, &FileConfig{
Filename: "./test.log",
DateSlice: "d",
})
logger.SetAsync()
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
logger.Info("benchmark logger message")
}
})
logger.Flush()
}
// go test -run=benchmark -cpu=1,2,4 -benchmem -benchtime=3s -bench="FileJson"
func BenchmarkLoggerFileJson(b *testing.B) {
logger := NewLogger()
logger.Detach("console")
logger.Attach("file", LOGGER_LEVEL_DEBUG, &FileConfig{
Filename: "./test.log",
DateSlice: "d",
JsonFormat: true,
})
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
logger.Info("benchmark logger message")
}
})
}