mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-11-21 14:44:00 +00:00
26 lines
721 B
Go
26 lines
721 B
Go
|
package logger
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"testing"
|
||
|
)
|
||
|
|
||
|
func TestFormatLogMessage(t *testing.T) {
|
||
|
f := func(format string, args []interface{}, maxArgLen int, expectedResult string) {
|
||
|
t.Helper()
|
||
|
result := formatLogMessage(maxArgLen, format, args)
|
||
|
if result != expectedResult {
|
||
|
t.Fatalf("unexpected result; got\n%q\nwant\n%q", result, expectedResult)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Zero format args
|
||
|
f("foobar", nil, 1, "foobar")
|
||
|
|
||
|
// Format args not exceeding the maxArgLen
|
||
|
f("foo: %d, %s, %s, %s", []interface{}{123, "bar", []byte("baz"), fmt.Errorf("abc")}, 3, "foo: 123, bar, baz, abc")
|
||
|
|
||
|
// Format args exceeding the maxArgLen
|
||
|
f("foo: %s, %q, %s", []interface{}{"abcde", fmt.Errorf("foo bar baz"), "xx"}, 4, `foo: a..e, "f..z", xx`)
|
||
|
}
|