VictoriaMetrics/lib/logstorage/pipe_fields_test.go

161 lines
2.7 KiB
Go
Raw Normal View History

2024-05-09 00:52:28 +00:00
package logstorage
import (
"testing"
)
2024-05-20 19:41:37 +00:00
func TestParsePipeFieldsSuccess(t *testing.T) {
f := func(pipeStr string) {
t.Helper()
expectParsePipeSuccess(t, pipeStr)
}
f(`fields *`)
f(`fields f1`)
f(`fields f1, f2, f3`)
}
func TestParsePipeFieldsFailure(t *testing.T) {
f := func(pipeStr string) {
t.Helper()
expectParsePipeFailure(t, pipeStr)
}
f(`fields`)
f(`fields x y`)
}
func TestPipeFields(t *testing.T) {
f := func(pipeStr string, rows, rowsExpected [][]Field) {
t.Helper()
expectPipeResults(t, pipeStr, rows, rowsExpected)
}
// single row, star
f("fields *", [][]Field{
{
{"_msg", `{"foo":"bar"}`},
{"a", `test`},
},
}, [][]Field{
{
{"_msg", `{"foo":"bar"}`},
{"a", `test`},
},
})
// single row, leave existing field
f("fields a", [][]Field{
{
{"_msg", `{"foo":"bar"}`},
{"a", `test`},
},
}, [][]Field{
{
{"a", `test`},
},
})
2024-05-20 19:47:30 +00:00
// single row, no existing fields
f("fields x, y", [][]Field{
{
{"_msg", `{"foo":"bar"}`},
{"a", `test`},
},
}, [][]Field{
{
{"x", ``},
{"y", ``},
},
})
2024-05-20 19:41:37 +00:00
// single row, mention existing field multiple times
2024-05-20 21:27:21 +00:00
f("fields a, a", [][]Field{
2024-05-20 19:41:37 +00:00
{
{"_msg", `{"foo":"bar"}`},
{"a", `test`},
},
}, [][]Field{
{
{"a", `test`},
},
})
// mention non-existing fields
f("fields foo, a, bar", [][]Field{
{
{"_msg", `{"foo":"bar"}`},
{"a", `test`},
},
}, [][]Field{
{
{"foo", ""},
{"bar", ""},
{"a", `test`},
},
})
// Multiple rows
f("fields a, b", [][]Field{
{
{"_msg", `{"foo":"bar"}`},
{"a", `test`},
},
{
{"a", `foobar`},
},
{
{"b", `baz`},
{"c", "d"},
{"e", "afdf"},
},
{
{"c", "dss"},
2024-05-20 21:27:21 +00:00
{"d", "df"},
2024-05-20 19:41:37 +00:00
},
}, [][]Field{
{
{"a", `test`},
2024-05-20 21:27:21 +00:00
{"b", ``},
2024-05-20 19:41:37 +00:00
},
{
{"a", `foobar`},
2024-05-20 21:27:21 +00:00
{"b", ""},
2024-05-20 19:41:37 +00:00
},
{
{"a", ""},
2024-05-20 21:27:21 +00:00
{"b", "baz"},
2024-05-20 19:41:37 +00:00
},
{
{"a", ""},
2024-05-20 21:27:21 +00:00
{"b", ""},
2024-05-20 19:41:37 +00:00
},
})
}
2024-05-09 00:52:28 +00:00
func TestPipeFieldsUpdateNeededFields(t *testing.T) {
f := func(s, neededFields, unneededFields, neededFieldsExpected, unneededFieldsExpected string) {
t.Helper()
2024-05-19 22:05:07 +00:00
expectPipeNeededFields(t, s, neededFields, unneededFields, neededFieldsExpected, unneededFieldsExpected)
2024-05-09 00:52:28 +00:00
}
// all the needed fields
f("fields s1, s2", "*", "", "s1,s2", "")
f("fields *", "*", "", "*", "")
// all the needed fields, unneeded fields do not intersect with src
f("fields s1, s2", "*", "f1,f2", "s1,s2", "")
f("fields *", "*", "f1,f2", "*", "f1,f2")
// all the needed fields, unneeded fields intersect with src
f("fields s1, s2", "*", "s1,f1,f2", "s2", "")
f("fields *", "*", "s1,f1,f2", "*", "s1,f1,f2")
// needed fields do not intersect with src
f("fields s1, s2", "f1,f2", "", "", "")
// needed fields intersect with src
f("fields s1, s2", "s1,f1,f2", "", "s1", "")
f("fields *", "s1,f1,f2", "", "s1,f1,f2", "")
}