2014-12-15 22:20:33 +03:00
|
|
|
package logrus
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"errors"
|
2017-02-14 13:53:03 +03:00
|
|
|
"strings"
|
2014-12-15 22:20:33 +03:00
|
|
|
"testing"
|
2015-03-27 02:04:45 +03:00
|
|
|
"time"
|
2014-12-15 22:20:33 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestQuoting(t *testing.T) {
|
2014-12-18 09:59:41 +03:00
|
|
|
tf := &TextFormatter{DisableColors: true}
|
2014-12-15 22:20:33 +03:00
|
|
|
|
|
|
|
checkQuoting := func(q bool, value interface{}) {
|
|
|
|
b, _ := tf.Format(WithField("test", value))
|
2014-12-18 09:59:41 +03:00
|
|
|
idx := bytes.Index(b, ([]byte)("test="))
|
2017-02-15 16:08:26 +03:00
|
|
|
cont := bytes.Contains(b[idx+5:], []byte(tf.QuoteCharacter))
|
2014-12-15 22:20:33 +03:00
|
|
|
if cont != q {
|
|
|
|
if q {
|
|
|
|
t.Errorf("quoting expected for: %#v", value)
|
|
|
|
} else {
|
|
|
|
t.Errorf("quoting not expected for: %#v", value)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-02-14 13:53:03 +03:00
|
|
|
checkQuoting(false, "")
|
2014-12-15 22:20:33 +03:00
|
|
|
checkQuoting(false, "abcd")
|
|
|
|
checkQuoting(false, "v1.0")
|
2015-03-04 17:04:50 +03:00
|
|
|
checkQuoting(false, "1234567890")
|
2017-06-18 16:48:52 +03:00
|
|
|
checkQuoting(false, "/foobar")
|
|
|
|
checkQuoting(false, "foo_bar")
|
|
|
|
checkQuoting(false, "foo@bar")
|
|
|
|
checkQuoting(false, "foobar^")
|
|
|
|
checkQuoting(false, "+/-_^@f.oobar")
|
|
|
|
checkQuoting(true, "foobar$")
|
|
|
|
checkQuoting(true, "&foobar")
|
2014-12-15 22:20:33 +03:00
|
|
|
checkQuoting(true, "x y")
|
|
|
|
checkQuoting(true, "x,y")
|
|
|
|
checkQuoting(false, errors.New("invalid"))
|
|
|
|
checkQuoting(true, errors.New("invalid argument"))
|
2017-02-14 13:53:03 +03:00
|
|
|
|
2017-02-15 16:08:26 +03:00
|
|
|
// Test for custom quote character.
|
|
|
|
tf.QuoteCharacter = "`"
|
2017-02-14 14:51:23 +03:00
|
|
|
checkQuoting(false, "")
|
|
|
|
checkQuoting(false, "abcd")
|
2017-06-18 16:48:52 +03:00
|
|
|
checkQuoting(false, "/foobar")
|
|
|
|
checkQuoting(false, "foo_bar")
|
|
|
|
checkQuoting(false, "foo@bar")
|
|
|
|
checkQuoting(false, "foobar^")
|
|
|
|
checkQuoting(true, "foobar$")
|
|
|
|
checkQuoting(true, "&foobar")
|
2017-02-14 14:51:23 +03:00
|
|
|
checkQuoting(true, errors.New("invalid argument"))
|
|
|
|
|
2017-02-15 16:08:26 +03:00
|
|
|
// Test for multi-character quotes.
|
|
|
|
tf.QuoteCharacter = "§~±"
|
|
|
|
checkQuoting(false, "abcd")
|
|
|
|
checkQuoting(true, errors.New("invalid argument"))
|
|
|
|
|
2017-02-14 14:51:23 +03:00
|
|
|
// Test for quoting empty fields.
|
2017-02-14 13:53:03 +03:00
|
|
|
tf.QuoteEmptyFields = true
|
|
|
|
checkQuoting(true, "")
|
2017-02-15 16:08:26 +03:00
|
|
|
checkQuoting(false, "abcd")
|
|
|
|
checkQuoting(true, errors.New("invalid argument"))
|
2014-12-15 22:20:33 +03:00
|
|
|
}
|
2015-03-09 18:19:51 +03:00
|
|
|
|
2015-03-27 02:04:45 +03:00
|
|
|
func TestTimestampFormat(t *testing.T) {
|
|
|
|
checkTimeStr := func(format string) {
|
|
|
|
customFormatter := &TextFormatter{DisableColors: true, TimestampFormat: format}
|
|
|
|
customStr, _ := customFormatter.Format(WithField("test", "test"))
|
|
|
|
timeStart := bytes.Index(customStr, ([]byte)("time="))
|
|
|
|
timeEnd := bytes.Index(customStr, ([]byte)("level="))
|
2017-02-15 16:08:26 +03:00
|
|
|
timeStr := customStr[timeStart+5+len(customFormatter.QuoteCharacter) : timeEnd-1-len(customFormatter.QuoteCharacter)]
|
2015-03-27 02:04:45 +03:00
|
|
|
if format == "" {
|
|
|
|
format = time.RFC3339
|
|
|
|
}
|
|
|
|
_, e := time.Parse(format, (string)(timeStr))
|
|
|
|
if e != nil {
|
|
|
|
t.Errorf("time string \"%s\" did not match provided time format \"%s\": %s", timeStr, format, e)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
checkTimeStr("2006-01-02T15:04:05.000000000Z07:00")
|
|
|
|
checkTimeStr("Mon Jan _2 15:04:05 2006")
|
|
|
|
checkTimeStr("")
|
|
|
|
}
|
|
|
|
|
2016-08-25 00:59:41 +03:00
|
|
|
func TestDisableTimestampWithColoredOutput(t *testing.T) {
|
|
|
|
tf := &TextFormatter{DisableTimestamp: true, ForceColors: true}
|
|
|
|
|
|
|
|
b, _ := tf.Format(WithField("test", "test"))
|
|
|
|
if strings.Contains(string(b), "[0000]") {
|
|
|
|
t.Error("timestamp not expected when DisableTimestamp is true")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-09 18:19:51 +03:00
|
|
|
// TODO add tests for sorting etc., this requires a parser for the text
|
|
|
|
// formatter output.
|