-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathzap_config_test.go
115 lines (111 loc) · 3.03 KB
/
zap_config_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
package zlog
import (
"encoding/json"
"github.com/luxun9527/zlog/report"
"github.com/spf13/viper"
"go.uber.org/zap"
"io"
"log"
"net/http"
"testing"
"time"
)
func TestDefaultConfig(t *testing.T) {
DevConfig.UpdateLevel(zap.DebugLevel)
Debugf("level %s", "debug")
Infof("level %s", "info")
Warnf("level %s", "warn")
Errorf("level %s", "error")
Panicf("level %s", "panic")
}
func TestProdConfig(t *testing.T) {
InitDefaultLogger(ProdConfig)
ProdConfig.UpdateLevel(zap.DebugLevel)
Debugf("level %s", "debug")
Infof("level %s", "info")
Warnf("level %s", "warn")
Errorf("level %s", "error")
Panicf("level %s", "panic")
}
func TestUpdateLogger(t *testing.T) {
ProdConfig.Port = 34567
InitDefaultLogger(ProdConfig)
//默认是info
Debugf("level %s", "debug")
Infof("level %s", "info")
Warnf("level %s", "warn")
Errorf("level %s", "error")
// curl -X PUT localhost:8080/log/level -d level=debug
// 支持 form和json格式
req, _ := http.NewRequest(http.MethodPut, "http://localhost:34567/log/level?level=debug", nil)
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
resp, err := http.DefaultClient.Do(req)
if err != nil {
log.Panicf("update level error %s", err.Error())
}
data, err := io.ReadAll(resp.Body)
if err != nil {
log.Panicf("read response error %s", err.Error())
}
defer resp.Body.Close()
var m = map[string]interface{}{}
if err := json.Unmarshal(data, &m); err != nil {
log.Panicf("unmarshal response error %s", err.Error())
}
log.Printf("update level response %v", m)
Debugf("level %s", "debug")
Debugf("level %s", "debug")
}
func TestReportLogger(t *testing.T) {
ProdConfig.ReportConfig = &report.ReportConfig{
Type: "lark",
Token: "https://open.feishu.cn/open-apis/bot/v2/hook/71fxxxxxxxxxxxxxxxxxxxxxxxxxxx",
}
InitDefaultLogger(ProdConfig)
//默认是info
Debugf("level %s", "debug")
Infof("level %s", "info")
Warnf("level %s", "warn")
Errorf("level %s", "error")
Panicf("level %s", "panic")
}
func TestFile(t *testing.T) {
DevConfig = &Config{
Level: zap.NewAtomicLevelAt(zap.InfoLevel),
Stacktrace: false,
AddCaller: true,
CallerShip: 1,
Mode: FileMode,
FileName: "./log/test.log",
//ErrorFileName: "./log/err.log",
MaxSize: 1,
MaxAge: 0,
MaxBackup: 5,
}
InitDefaultLogger(DevConfig)
for i := 0; i < 100; i++ {
for j := 0; j < 10000; j++ {
Infof("level %s", "info")
Warnf("level %s", "warn")
Errorf("level %s", "error")
}
}
}
func TestViperConfig(t *testing.T) {
v := viper.New()
v.SetConfigFile("./config.yaml")
if err := v.ReadInConfig(); err != nil {
log.Panicf("read config file failed, err:%v", err)
}
var c Config
if err := v.Unmarshal(&c, viper.DecodeHook(StringToLogLevelHookFunc())); err != nil {
log.Panicf("Unmarshal config file failed, err:%v", err)
}
InitDefaultLogger(&c)
Debug("debug level ", String("test", "test"))
Info("info level ", Duration("Duration", time.Second))
Warn("warn level ", Any("test", "test"))
Error("error level ", Any("test", "test"))
Panic("panic level ", Any("test", "test"))
Sync()
}