mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-12-31 15:06:26 +00:00
wip
This commit is contained in:
parent
fbf1485f14
commit
c5c96d8016
4 changed files with 116 additions and 2 deletions
|
@ -32,7 +32,7 @@ func (pc *pipeCopy) String() string {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (pc *pipeCopy) updateNeededFields(neededFields, unneededFields fieldsSet) {
|
func (pc *pipeCopy) updateNeededFields(neededFields, unneededFields fieldsSet) {
|
||||||
for i := len(pc.srcFields)-1; i >=0 ; i-- {
|
for i := len(pc.srcFields) - 1; i >= 0; i-- {
|
||||||
srcField := pc.srcFields[i]
|
srcField := pc.srcFields[i]
|
||||||
dstField := pc.dstFields[i]
|
dstField := pc.dstFields[i]
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,107 @@ import (
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func TestParsePipeDeleteSuccess(t *testing.T) {
|
||||||
|
f := func(pipeStr string) {
|
||||||
|
t.Helper()
|
||||||
|
expectParsePipeSuccess(t, pipeStr)
|
||||||
|
}
|
||||||
|
|
||||||
|
f(`delete f1`)
|
||||||
|
f(`delete f1, f2`)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestParsePipeDeleteFailure(t *testing.T) {
|
||||||
|
f := func(pipeStr string) {
|
||||||
|
t.Helper()
|
||||||
|
expectParsePipeFailure(t, pipeStr)
|
||||||
|
}
|
||||||
|
|
||||||
|
f(`delete`)
|
||||||
|
f(`delete x y`)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPipeDelete(t *testing.T) {
|
||||||
|
f := func(pipeStr string, rows, rowsExpected [][]Field) {
|
||||||
|
t.Helper()
|
||||||
|
expectPipeResults(t, pipeStr, rows, rowsExpected)
|
||||||
|
}
|
||||||
|
|
||||||
|
// single row, drop existing field
|
||||||
|
f("delete _msg", [][]Field{
|
||||||
|
{
|
||||||
|
{"_msg", `{"foo":"bar"}`},
|
||||||
|
{"a", `test`},
|
||||||
|
},
|
||||||
|
}, [][]Field{
|
||||||
|
{
|
||||||
|
{"a", `test`},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
// single row, drop existing field multiple times
|
||||||
|
f("delete _msg, _msg", [][]Field{
|
||||||
|
{
|
||||||
|
{"_msg", `{"foo":"bar"}`},
|
||||||
|
{"a", `test`},
|
||||||
|
},
|
||||||
|
}, [][]Field{
|
||||||
|
{
|
||||||
|
{"a", `test`},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
// single row, drop all the fields
|
||||||
|
f("delete a, _msg", [][]Field{
|
||||||
|
{
|
||||||
|
{"_msg", `{"foo":"bar"}`},
|
||||||
|
{"a", `test`},
|
||||||
|
},
|
||||||
|
}, [][]Field{})
|
||||||
|
|
||||||
|
// delete non-existing fields
|
||||||
|
f("delete foo, _msg, bar", [][]Field{
|
||||||
|
{
|
||||||
|
{"_msg", `{"foo":"bar"}`},
|
||||||
|
{"a", `test`},
|
||||||
|
},
|
||||||
|
}, [][]Field{
|
||||||
|
{
|
||||||
|
{"a", `test`},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
// Multiple rows
|
||||||
|
f("delete _msg, a", [][]Field{
|
||||||
|
{
|
||||||
|
{"_msg", `{"foo":"bar"}`},
|
||||||
|
{"a", `test`},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{"a", `foobar`},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{"b", `baz`},
|
||||||
|
{"c", "d"},
|
||||||
|
{"e", "afdf"},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{"c", "dss"},
|
||||||
|
{"b", "df"},
|
||||||
|
},
|
||||||
|
}, [][]Field{
|
||||||
|
{
|
||||||
|
{"b", `baz`},
|
||||||
|
{"c", "d"},
|
||||||
|
{"e", "afdf"},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{"c", "dss"},
|
||||||
|
{"b", "df"},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func TestPipeDeleteUpdateNeededFields(t *testing.T) {
|
func TestPipeDeleteUpdateNeededFields(t *testing.T) {
|
||||||
f := func(s, neededFields, unneededFields, neededFieldsExpected, unneededFieldsExpected string) {
|
f := func(s, neededFields, unneededFields, neededFieldsExpected, unneededFieldsExpected string) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
|
|
|
@ -56,6 +56,19 @@ func TestPipeFields(t *testing.T) {
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
|
// single row, no existing fields
|
||||||
|
f("fields x, y", [][]Field{
|
||||||
|
{
|
||||||
|
{"_msg", `{"foo":"bar"}`},
|
||||||
|
{"a", `test`},
|
||||||
|
},
|
||||||
|
}, [][]Field{
|
||||||
|
{
|
||||||
|
{"x", ``},
|
||||||
|
{"y", ``},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
// single row, mention existing field multiple times
|
// single row, mention existing field multiple times
|
||||||
f("fileds a, a", [][]Field{
|
f("fileds a, a", [][]Field{
|
||||||
{
|
{
|
||||||
|
|
|
@ -32,7 +32,7 @@ func (pr *pipeRename) String() string {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (pr *pipeRename) updateNeededFields(neededFields, unneededFields fieldsSet) {
|
func (pr *pipeRename) updateNeededFields(neededFields, unneededFields fieldsSet) {
|
||||||
for i := len(pr.srcFields)-1; i >=0 ; i-- {
|
for i := len(pr.srcFields) - 1; i >= 0; i-- {
|
||||||
srcField := pr.srcFields[i]
|
srcField := pr.srcFields[i]
|
||||||
dstField := pr.dstFields[i]
|
dstField := pr.dstFields[i]
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue