2021-05-29 02:23:10 -04:00
|
|
|
package mlog
|
|
|
|
|
|
|
|
import (
|
|
|
|
"sync"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/mattermost/logr/v2"
|
|
|
|
"github.com/mattermost/logr/v2/formatters"
|
|
|
|
)
|
|
|
|
|
2021-06-21 05:21:42 -04:00
|
|
|
// CreateTestLogger creates a logger for unit tests. Log records are output to `(*testing.T)Log`.
|
2021-05-29 02:23:10 -04:00
|
|
|
func CreateTestLogger(t *testing.T, levels ...Field) (logger *Logger) {
|
|
|
|
logger = NewLogger()
|
|
|
|
|
|
|
|
filter := logr.NewCustomFilter(StdAll...)
|
|
|
|
formatter := &formatters.Plain{}
|
|
|
|
target := newTestingTarget(t)
|
|
|
|
|
2021-06-21 05:21:42 -04:00
|
|
|
if err := logger.log.Logr().AddTarget(target, "test", filter, formatter, 1000); err != nil {
|
|
|
|
t.Fail()
|
|
|
|
return nil
|
|
|
|
}
|
2021-05-29 02:23:10 -04:00
|
|
|
return logger
|
|
|
|
}
|
|
|
|
|
|
|
|
// testingTarget is a simple log target that writes to the testing log.
|
|
|
|
type testingTarget struct {
|
|
|
|
mux sync.Mutex
|
|
|
|
t *testing.T
|
|
|
|
}
|
|
|
|
|
|
|
|
func newTestingTarget(t *testing.T) *testingTarget {
|
|
|
|
return &testingTarget{
|
|
|
|
t: t,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init is called once to initialize the target.
|
|
|
|
func (tt *testingTarget) Init() error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Write outputs bytes to this file target.
|
|
|
|
func (tt *testingTarget) Write(p []byte, rec *logr.LogRec) (int, error) {
|
|
|
|
tt.mux.Lock()
|
|
|
|
defer tt.mux.Unlock()
|
|
|
|
|
|
|
|
if tt.t != nil {
|
|
|
|
tt.t.Log(string(p))
|
|
|
|
}
|
|
|
|
return len(p), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Shutdown is called once to free/close any resources.
|
|
|
|
// Target queue is already drained when this is called.
|
|
|
|
func (tt *testingTarget) Shutdown() error {
|
|
|
|
tt.mux.Lock()
|
|
|
|
defer tt.mux.Unlock()
|
|
|
|
|
|
|
|
tt.t = nil
|
|
|
|
return nil
|
|
|
|
}
|