-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathlogger_test.go
188 lines (147 loc) · 4.71 KB
/
logger_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
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
package logging
import (
"context"
"log/slog"
"os"
"path"
"strings"
"testing"
)
func TestNewLogger(t *testing.T) {
ctx := context.Background()
logger := NewLogger()
if logger == nil {
t.Errorf("logger should not be nil")
}
if Default() != logger {
t.Errorf("logger should be default logger")
}
if slog.Default() != Default() {
t.Errorf("logger should be default logger")
}
if logger != Default() {
t.Errorf("logger should be default logger")
}
logger = NewLogger(WithIsJSON(true))
if slog.Default() != logger {
t.Errorf("logger should be default logger")
}
_ = NewLogger(WithIsJSON(false))
if slog.Default() == logger {
t.Errorf("logger should NOT be default logger")
}
logger = NewLogger(WithLevel("info"))
if logger.Handler().Enabled(ctx, LevelDebug) {
t.Errorf("logger should NOT be enabled for debug level")
}
logger = NewLogger(WithLevel("warn"))
if logger.Handler().Enabled(ctx, LevelDebug) {
t.Errorf("logger should NOT be enabled for debug level")
}
logger = NewLogger(WithLevel("debug"))
enabled := []Level{LevelDebug, LevelInfo, LevelWarn, LevelError}
for _, level := range enabled {
if !logger.Handler().Enabled(ctx, level) {
t.Errorf("logger should be enabled for all levels")
}
}
logger = NewLogger(WithLevel("abcdef"))
if !logger.Handler().Enabled(ctx, LevelInfo) {
t.Errorf("logger should be enabled for info level")
}
if logger.Handler().Enabled(ctx, LevelDebug) {
t.Errorf("logger should NOT be enabled for info level")
}
logger = NewLogger(WithAddSource(true))
if slog.Default() != logger {
t.Errorf("logger should be default logger")
}
logger = NewLogger(WithSetDefault(false))
if slog.Default() == logger {
t.Errorf("logger should NOT be default logger")
}
if logger == Default() {
t.Errorf("logger should NOT be default logger")
}
if L(ctx) == logger {
t.Errorf("logger should NOT be from context logger")
}
logger = NewLogger(WithAddSource(false), WithIsJSON(false))
ctx = ContextWithLogger(ctx, logger)
if L(ctx) != logger {
t.Errorf("logger should be from context logger")
}
}
func TestLoggerWithFile(t *testing.T) {
tempFile, err := os.CreateTemp("", "logfile_*.log")
if err != nil {
t.Fatalf("Failed to create temporary log file: %v", err)
}
defer os.Remove(tempFile.Name())
logger := NewLogger(WithLogFilePath(tempFile.Name()), WithIsJSON(false))
if logger == nil {
t.Fatalf("Failed to create logger with file output")
}
testMessage := "This is a test log message"
logger.Info(testMessage)
// Check file content
content, err := os.ReadFile(tempFile.Name())
if err != nil {
t.Fatalf("Failed to read log file: %v", err)
}
if !strings.Contains(string(content), testMessage) {
t.Errorf("Log file does not contain expected message. Got: %s", string(content))
}
}
func TestLoggerRotationRetention(t *testing.T) {
tempDir := "./" + "logs"
err := os.Mkdir(tempDir, 0755) // 0755 defines the permissions
if err != nil {
t.Errorf("Failed to create temporary directory: %v", err)
}
defer os.RemoveAll(tempDir)
fileName := "all-log"
logFilePath := path.Join(tempDir, fileName+".log")
maxSizeMB := 1
maxBackups := 3
NewLogger(
WithLogFilePath(logFilePath),
WithLogFileMaxSizeMB(maxSizeMB), // 1 MB for testing
WithLogFileMaxBackups(maxBackups), // Keep only 1 backup
WithLogFileCompress(false),
WithIsJSON(false),
WithSetDefault(true),
)
if Default() == nil {
t.Fatalf("Failed to create logger")
}
logMessage := "This is a sample log entry for testing purposes."
messageSize := len(logMessage)
targetSize := maxSizeMB*1024*1024 + 5000
for currentSize := 0; currentSize < targetSize; currentSize += messageSize {
Default().Info(logMessage, IntAttr("currentSize", currentSize))
}
// Отладочное сообщение для проверки состояния
t.Logf("Log file path: %s", logFilePath)
// Проверяем количество файлов, созданных логгером
files, err := os.ReadDir(tempDir)
if err != nil {
t.Fatalf("Failed to read temporary directory: %v", err)
}
// Фильтруем файлы, связанные с логгером
var matchingFiles []os.DirEntry
for _, file := range files {
if strings.HasPrefix(file.Name(), fileName) {
matchingFiles = append(matchingFiles, file)
}
}
if len(matchingFiles) == 0 {
t.Errorf("No log files were created. Check lumberjack configuration or logger output.")
} else if len(matchingFiles) != maxBackups+1 { // 1 current file + 1 backup
t.Errorf("Expected exactly 2 log files (1 current + 1 backup), found %d", len(matchingFiles))
}
// Отладочная информация о найденных файлах
for _, file := range matchingFiles {
t.Logf("Found log file: %s", file.Name())
}
}