forked from muxi-Infra/muxi-micro
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlogs_test.go
More file actions
68 lines (55 loc) · 1.45 KB
/
logs_test.go
File metadata and controls
68 lines (55 loc) · 1.45 KB
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
package logx
import (
"bytes"
"log"
"strings"
"testing"
"github.com/muxi-Infra/muxi-micro/pkg/logger"
)
func TestNewStdLogger(t *testing.T) {
l := NewStdLogger()
if l == nil {
t.Fatal("expected logger, got nil")
}
if l.logger == nil {
t.Fatal("expected underlying log.Logger initialized")
}
}
func TestOutputLevels(t *testing.T) {
l := NewStdLogger()
fields := logger.Field{"key": "value"}
l.Info("info msg", fields)
l.Debug("debug msg")
l.Warn("warn msg")
l.Error("error msg")
}
func TestWithFields(t *testing.T) {
l := NewStdLogger()
// 添加初始字段
l2 := l.With(logger.Field{"request_id": "1234"}).(*StdLogger)
if v, ok := l2.fields["request_id"]; !ok || v != "1234" {
t.Fatalf("expected field request_id=1234, got %v", l2.fields)
}
// 再添加新字段(测试合并)
l3 := l2.With(logger.Field{"user": "alice"}).(*StdLogger)
if v, ok := l3.fields["user"]; !ok || v != "alice" {
t.Fatalf("expected user=alice, got %v", l3.fields)
}
}
func TestOutputFieldMerging(t *testing.T) {
l := NewStdLogger()
buf := &bytes.Buffer{}
l.logger = log.New(buf, "", 0)
l.fields["base"] = "yes"
l.output("INFO", "test", logger.Field{"child": "ok"})
out := buf.String()
if !strings.Contains(out, "\"base\":\"yes\"") || !strings.Contains(out, "\"child\":\"ok\"") {
t.Fatalf("field merge failed: %s", out)
}
}
func TestSync(t *testing.T) {
l := NewStdLogger()
if err := l.Sync(); err != nil {
t.Fatalf("expected nil, got %v", err)
}
}