mirror of
https://github.com/astaxie/beego.git
synced 2024-11-05 06:30:54 +00:00
Add unit tests for custom log formatter
Also moved is Colorful check to WriteMsg function to make the interface for user's using the custom logging formatting simpler. The user does not have to check if the text is colorful now, the WriteMsg function handles it.
This commit is contained in:
parent
0189e6329a
commit
8982f5d702
@ -58,10 +58,6 @@ type consoleWriter struct {
|
|||||||
func (c *consoleWriter) Format(lm *LogMsg) string {
|
func (c *consoleWriter) Format(lm *LogMsg) string {
|
||||||
msg := lm.Msg
|
msg := lm.Msg
|
||||||
|
|
||||||
if c.Colorful {
|
|
||||||
msg = strings.Replace(lm.Msg, levelPrefix[lm.Level], colors[lm.Level](levelPrefix[lm.Level]), 1)
|
|
||||||
}
|
|
||||||
|
|
||||||
h, _, _ := formatTimeHeader(lm.When)
|
h, _, _ := formatTimeHeader(lm.When)
|
||||||
bytes := append(append(h, msg...), '\n')
|
bytes := append(append(h, msg...), '\n')
|
||||||
|
|
||||||
@ -105,13 +101,13 @@ func (c *consoleWriter) WriteMsg(lm *LogMsg) error {
|
|||||||
if lm.Level > c.Level {
|
if lm.Level > c.Level {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
// fmt.Printf("Formatted: %s\n\n", c.fmtter.Format(lm))
|
|
||||||
|
msg := ""
|
||||||
|
|
||||||
if c.Colorful {
|
if c.Colorful {
|
||||||
lm.Msg = strings.Replace(lm.Msg, levelPrefix[lm.Level], colors[lm.Level](levelPrefix[lm.Level]), 1)
|
lm.Msg = strings.Replace(lm.Msg, levelPrefix[lm.Level], colors[lm.Level](levelPrefix[lm.Level]), 1)
|
||||||
}
|
}
|
||||||
|
|
||||||
msg := ""
|
|
||||||
|
|
||||||
if c.customFormatter != nil {
|
if c.customFormatter != nil {
|
||||||
msg = c.customFormatter(lm)
|
msg = c.customFormatter(lm)
|
||||||
} else {
|
} else {
|
||||||
|
36
pkg/logs/logformattertest/log_formatter_test.go
Normal file
36
pkg/logs/logformattertest/log_formatter_test.go
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
package logformattertest
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/astaxie/beego/pkg/common"
|
||||||
|
"github.com/astaxie/beego/pkg/logs"
|
||||||
|
)
|
||||||
|
|
||||||
|
func customFormatter(lm *logs.LogMsg) string {
|
||||||
|
return fmt.Sprintf("[CUSTOM CONSOLE LOGGING] %s", lm.Msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
func globalFormatter(lm *logs.LogMsg) string {
|
||||||
|
return fmt.Sprintf("[GLOBAL] %s", lm.Msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestCustomLoggingFormatter(t *testing.T) {
|
||||||
|
// beego.BConfig.Log.AccessLogs = true
|
||||||
|
|
||||||
|
logs.SetLoggerWithOpts("console", []string{`{"color":true}`}, common.SimpleKV{Key: "formatter", Value: customFormatter})
|
||||||
|
|
||||||
|
// Message will be formatted by the customFormatter with colorful text set to true
|
||||||
|
logs.Informational("Test message")
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestGlobalLoggingFormatter(t *testing.T) {
|
||||||
|
logs.SetGlobalFormatter(globalFormatter)
|
||||||
|
|
||||||
|
logs.SetLogger("console", `{"color":true}`)
|
||||||
|
|
||||||
|
// Message will be formatted by globalFormatter
|
||||||
|
logs.Informational("Test message")
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user