mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-12-01 14:47:38 +00:00
57 lines
1.4 KiB
Go
57 lines
1.4 KiB
Go
|
package logstorage
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
)
|
||
|
|
||
|
func TestParsePipeJoinSuccess(t *testing.T) {
|
||
|
f := func(pipeStr string) {
|
||
|
t.Helper()
|
||
|
expectParsePipeSuccess(t, pipeStr)
|
||
|
}
|
||
|
|
||
|
f(`join by (foo) (error)`)
|
||
|
f(`join by (foo, bar) (a:b | fields x, y)`)
|
||
|
}
|
||
|
|
||
|
func TestParsePipeJoinFailure(t *testing.T) {
|
||
|
f := func(pipeStr string) {
|
||
|
t.Helper()
|
||
|
expectParsePipeFailure(t, pipeStr)
|
||
|
}
|
||
|
|
||
|
f(`join`)
|
||
|
f(`join by () (abc)`)
|
||
|
f(`join by (*) (abc)`)
|
||
|
f(`join by (f, *) (abc)`)
|
||
|
f(`join by (x)`)
|
||
|
f(`join by`)
|
||
|
f(`join (`)
|
||
|
f(`join by (foo) bar`)
|
||
|
f(`join by (x) ()`)
|
||
|
f(`join by (x) (`)
|
||
|
f(`join by (x) (abc`)
|
||
|
}
|
||
|
|
||
|
func TestPipeJoinUpdateNeededFields(t *testing.T) {
|
||
|
f := func(s string, neededFields, unneededFields, neededFieldsExpected, unneededFieldsExpected string) {
|
||
|
t.Helper()
|
||
|
expectPipeNeededFields(t, s, neededFields, unneededFields, neededFieldsExpected, unneededFieldsExpected)
|
||
|
}
|
||
|
|
||
|
// all the needed fields
|
||
|
f("join on (x, y) (abc)", "*", "", "*", "")
|
||
|
|
||
|
// all the needed fields, unneeded fields do not intersect with src
|
||
|
f("join on (x, y) (abc)", "*", "f1,f2", "*", "f1,f2")
|
||
|
|
||
|
// all the needed fields, unneeded fields intersect with src
|
||
|
f("join on (x, y) (abc)", "*", "f2,x", "*", "f2")
|
||
|
|
||
|
// needed fields do not intersect with src
|
||
|
f("join on (x, y) (abc)", "f1,f2", "", "f1,f2,x,y", "")
|
||
|
|
||
|
// needed fields intersect with src
|
||
|
f("join on (x, y) (abc)", "f2,x", "", "f2,x,y", "")
|
||
|
}
|