forked from checkout/checkout-sdk-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlog_test.go
117 lines (92 loc) · 2.54 KB
/
log_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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package checkout
import (
"bytes"
"testing"
assert "github.com/stretchr/testify/require"
)
//
// Tests
//
func TestDefaultLeveledLogger(t *testing.T) {
_, ok := DefaultLeveledLogger.(*LeveledLogger)
assert.True(t, ok)
}
//
// LeveledLogger
//
func TestLeveledLoggerDebugf(t *testing.T) {
var stdout, stderr bytes.Buffer
logger := &LeveledLogger{stdoutOverride: &stdout, stderrOverride: &stderr}
{
clearBuffers(&stdout, &stderr)
logger.Level = LevelDebug
logger.Debugf("test")
assert.Equal(t, "[DEBUG] test\n", stdout.String())
assert.Equal(t, "", stderr.String())
}
// Expect no logging
for _, level := range []Level{LevelInfo, LevelWarn, LevelError} {
clearBuffers(&stdout, &stderr)
logger.Level = level
logger.Debugf("test")
assert.Equal(t, "", stdout.String())
assert.Equal(t, "", stderr.String())
}
}
func TestLeveledLoggerInfof(t *testing.T) {
var stdout, stderr bytes.Buffer
logger := &LeveledLogger{stdoutOverride: &stdout, stderrOverride: &stderr}
for _, level := range []Level{LevelDebug, LevelInfo} {
clearBuffers(&stdout, &stderr)
logger.Level = level
logger.Infof("test")
assert.Equal(t, "[INFO] test\n", stdout.String())
assert.Equal(t, "", stderr.String())
}
// Expect no logging
for _, level := range []Level{LevelWarn, LevelError} {
clearBuffers(&stdout, &stderr)
logger.Level = level
logger.Infof("test")
assert.Equal(t, "", stdout.String())
assert.Equal(t, "", stderr.String())
}
}
func TestLeveledLoggerWarnf(t *testing.T) {
var stdout, stderr bytes.Buffer
logger := &LeveledLogger{stdoutOverride: &stdout, stderrOverride: &stderr}
for _, level := range []Level{LevelDebug, LevelInfo, LevelWarn} {
clearBuffers(&stdout, &stderr)
logger.Level = level
logger.Warnf("test")
assert.Equal(t, "", stdout.String())
assert.Equal(t, "[WARN] test\n", stderr.String())
}
// Expect no logging
{
clearBuffers(&stdout, &stderr)
logger.Level = LevelError
logger.Warnf("test")
assert.Equal(t, "", stdout.String())
assert.Equal(t, "", stderr.String())
}
}
func TestLeveledLoggerErrorf(t *testing.T) {
var stdout, stderr bytes.Buffer
logger := &LeveledLogger{stdoutOverride: &stdout, stderrOverride: &stderr}
for _, level := range []Level{LevelDebug, LevelInfo, LevelWarn, LevelError} {
clearBuffers(&stdout, &stderr)
logger.Level = level
logger.Errorf("test")
assert.Equal(t, "[ERROR] test\n", stdout.String())
assert.Equal(t, "", stderr.String())
}
}
//
// Private functions
//
func clearBuffers(buffers ...*bytes.Buffer) {
for _, b := range buffers {
b.Truncate(0)
}
}