mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-10 15:14:09 +00:00
bac193e50b
Empty fields are treated as non-existing fields by VictoriaLogs data model. So there is no sense in returning empty fields in query results, since they may mislead and confuse users.
130 lines
4.2 KiB
Go
130 lines
4.2 KiB
Go
package syslog
|
|
|
|
import (
|
|
"bytes"
|
|
"reflect"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/VictoriaMetrics/VictoriaMetrics/app/vlinsert/insertutils"
|
|
)
|
|
|
|
func TestSyslogLineReader_Success(t *testing.T) {
|
|
f := func(data string, linesExpected []string) {
|
|
t.Helper()
|
|
|
|
r := bytes.NewBufferString(data)
|
|
slr := getSyslogLineReader(r)
|
|
defer putSyslogLineReader(slr)
|
|
|
|
var lines []string
|
|
for slr.nextLine() {
|
|
lines = append(lines, string(slr.line))
|
|
}
|
|
if err := slr.Error(); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
}
|
|
if !reflect.DeepEqual(lines, linesExpected) {
|
|
t.Fatalf("unexpected lines read;\ngot\n%q\nwant\n%q", lines, linesExpected)
|
|
}
|
|
}
|
|
|
|
f("", nil)
|
|
f("\n", nil)
|
|
f("\n\n\n", nil)
|
|
|
|
f("foobar", []string{"foobar"})
|
|
f("foobar\n", []string{"foobar\n"})
|
|
f("\n\nfoo\n\nbar\n\n", []string{"foo\n\nbar\n\n"})
|
|
|
|
f(`Jun 3 12:08:33 abcd systemd: Starting Update the local ESM caches...`, []string{"Jun 3 12:08:33 abcd systemd: Starting Update the local ESM caches..."})
|
|
|
|
f(`Jun 3 12:08:33 abcd systemd: Starting Update the local ESM caches...
|
|
|
|
48 <165>Jun 4 12:08:33 abcd systemd[345]: abc defg<123>1 2023-06-03T17:42:12.345Z mymachine.example.com appname 12345 ID47 [exampleSDID@32473 iut="3" eventSource="Application 123 = ] 56" eventID="11211"] This is a test message with structured data.
|
|
|
|
`, []string{
|
|
"Jun 3 12:08:33 abcd systemd: Starting Update the local ESM caches...",
|
|
"<165>Jun 4 12:08:33 abcd systemd[345]: abc defg",
|
|
`<123>1 2023-06-03T17:42:12.345Z mymachine.example.com appname 12345 ID47 [exampleSDID@32473 iut="3" eventSource="Application 123 = ] 56" eventID="11211"] This is a test message with structured data.`,
|
|
})
|
|
}
|
|
|
|
func TestSyslogLineReader_Failure(t *testing.T) {
|
|
f := func(data string) {
|
|
t.Helper()
|
|
|
|
r := bytes.NewBufferString(data)
|
|
slr := getSyslogLineReader(r)
|
|
defer putSyslogLineReader(slr)
|
|
|
|
if slr.nextLine() {
|
|
t.Fatalf("expecting failure to read the first line")
|
|
}
|
|
if err := slr.Error(); err == nil {
|
|
t.Fatalf("expecting non-nil error")
|
|
}
|
|
}
|
|
|
|
// invalid format for message size
|
|
f("12foo bar")
|
|
|
|
// too big message size
|
|
f("123 aa")
|
|
f("1233423432 abc")
|
|
}
|
|
|
|
func TestProcessStreamInternal_Success(t *testing.T) {
|
|
f := func(data string, currentYear, rowsExpected int, timestampsExpected []int64, resultExpected string) {
|
|
t.Helper()
|
|
|
|
MustInit()
|
|
defer MustStop()
|
|
|
|
globalTimezone = time.UTC
|
|
globalCurrentYear.Store(int64(currentYear))
|
|
|
|
tlp := &insertutils.TestLogMessageProcessor{}
|
|
r := bytes.NewBufferString(data)
|
|
if err := processStreamInternal(r, "", false, tlp); err != nil {
|
|
t.Fatalf("unexpected error: %s", err)
|
|
}
|
|
if err := tlp.Verify(rowsExpected, timestampsExpected, resultExpected); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
data := `Jun 3 12:08:33 abcd systemd: Starting Update the local ESM caches...
|
|
|
|
48 <165>Jun 4 12:08:33 abcd systemd[345]: abc defg<123>1 2023-06-03T17:42:12.345Z mymachine.example.com appname 12345 ID47 [exampleSDID@32473 iut="3" eventSource="Application 123 = ] 56" eventID="11211"] This is a test message with structured data.
|
|
`
|
|
currentYear := 2023
|
|
rowsExpected := 3
|
|
timestampsExpected := []int64{1685794113000000000, 1685880513000000000, 1685814132345000000}
|
|
resultExpected := `{"format":"rfc3164","hostname":"abcd","app_name":"systemd","_msg":"Starting Update the local ESM caches..."}
|
|
{"priority":"165","facility":"20","severity":"5","format":"rfc3164","hostname":"abcd","app_name":"systemd","proc_id":"345","_msg":"abc defg"}
|
|
{"priority":"123","facility":"15","severity":"3","format":"rfc5424","hostname":"mymachine.example.com","app_name":"appname","proc_id":"12345","msg_id":"ID47","exampleSDID@32473.iut":"3","exampleSDID@32473.eventSource":"Application 123 = ] 56","exampleSDID@32473.eventID":"11211","_msg":"This is a test message with structured data."}`
|
|
f(data, currentYear, rowsExpected, timestampsExpected, resultExpected)
|
|
}
|
|
|
|
func TestProcessStreamInternal_Failure(t *testing.T) {
|
|
f := func(data string) {
|
|
t.Helper()
|
|
|
|
MustInit()
|
|
defer MustStop()
|
|
|
|
tlp := &insertutils.TestLogMessageProcessor{}
|
|
r := bytes.NewBufferString(data)
|
|
if err := processStreamInternal(r, "", false, tlp); err == nil {
|
|
t.Fatalf("expecting non-nil error")
|
|
}
|
|
}
|
|
|
|
// invalid format for message size
|
|
f("12foo bar")
|
|
|
|
// too big message size
|
|
f("123 foo")
|
|
f("123456789 bar")
|
|
}
|