mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-12-22 16:36:27 +01:00
55 lines
950 B
Go
55 lines
950 B
Go
|
package log
|
||
|
|
||
|
import (
|
||
|
"bytes"
|
||
|
"fmt"
|
||
|
"strings"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/logger"
|
||
|
)
|
||
|
|
||
|
func TestOutput(t *testing.T) {
|
||
|
testOutput := &bytes.Buffer{}
|
||
|
logger.SetOutputForTests(testOutput)
|
||
|
defer logger.ResetOutputForTest()
|
||
|
|
||
|
log := &Logger{}
|
||
|
|
||
|
mustMatch := func(exp string) {
|
||
|
t.Helper()
|
||
|
if exp == "" {
|
||
|
if testOutput.String() != "" {
|
||
|
t.Errorf("expected output to be empty; got %q", testOutput.String())
|
||
|
return
|
||
|
}
|
||
|
}
|
||
|
if !strings.Contains(testOutput.String(), exp) {
|
||
|
t.Errorf("output %q should contain %q", testOutput.String(), exp)
|
||
|
}
|
||
|
fmt.Println(testOutput.String())
|
||
|
testOutput.Reset()
|
||
|
}
|
||
|
|
||
|
log.Warnf("foo")
|
||
|
mustMatch("foo")
|
||
|
|
||
|
log.Infof("info %d", 2)
|
||
|
mustMatch("info 2")
|
||
|
|
||
|
log.Errorf("error %s %d", "baz", 5)
|
||
|
mustMatch("error baz 5")
|
||
|
|
||
|
log.Suppress(true)
|
||
|
|
||
|
log.Warnf("foo")
|
||
|
mustMatch("")
|
||
|
|
||
|
log.Infof("info %d", 2)
|
||
|
mustMatch("")
|
||
|
|
||
|
log.Errorf("error %q %d", "baz", 5)
|
||
|
mustMatch("")
|
||
|
|
||
|
}
|