2024-06-17 10:13:18 +00:00
|
|
|
package logstorage
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestParsePipeTopSuccess(t *testing.T) {
|
|
|
|
f := func(pipeStr string) {
|
|
|
|
t.Helper()
|
|
|
|
expectParsePipeSuccess(t, pipeStr)
|
|
|
|
}
|
|
|
|
|
|
|
|
f(`top`)
|
2024-10-29 14:37:07 +00:00
|
|
|
f(`top with rank`)
|
2024-06-17 10:13:18 +00:00
|
|
|
f(`top 5`)
|
2024-10-29 14:37:07 +00:00
|
|
|
f(`top 5 with rank as foo`)
|
2024-06-17 10:13:18 +00:00
|
|
|
f(`top by (x)`)
|
|
|
|
f(`top 5 by (x)`)
|
|
|
|
f(`top by (x, y)`)
|
|
|
|
f(`top 5 by (x, y)`)
|
2024-10-29 14:37:07 +00:00
|
|
|
f(`top by (x) with rank`)
|
|
|
|
f(`top by (x) with rank as foo`)
|
2024-06-17 10:13:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestParsePipeTopFailure(t *testing.T) {
|
|
|
|
f := func(pipeStr string) {
|
|
|
|
t.Helper()
|
|
|
|
expectParsePipeFailure(t, pipeStr)
|
|
|
|
}
|
|
|
|
|
|
|
|
f(`top 5 foo`)
|
|
|
|
f(`top 5 by`)
|
|
|
|
f(`top 5 by (`)
|
|
|
|
f(`top 5foo`)
|
|
|
|
f(`top foo`)
|
|
|
|
f(`top by`)
|
2024-10-29 14:37:07 +00:00
|
|
|
f(`top (x) with`)
|
|
|
|
f(`top (x) with rank as`)
|
2024-06-17 10:13:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestPipeTop(t *testing.T) {
|
|
|
|
f := func(pipeStr string, rows, rowsExpected [][]Field) {
|
|
|
|
t.Helper()
|
|
|
|
expectPipeResults(t, pipeStr, rows, rowsExpected)
|
|
|
|
}
|
|
|
|
|
|
|
|
f("top", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
{"hits", "2"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
{"hits", "1"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2024-10-29 14:37:07 +00:00
|
|
|
f("top with rank", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
{"hits", "2"},
|
|
|
|
{"rank", "1"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
{"hits", "1"},
|
|
|
|
{"rank", "2"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2024-06-17 10:13:18 +00:00
|
|
|
f("top 1", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
{"hits", "2"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
f("top by (a)", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"hits", "3"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
f("top by (b)", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"b", "3"},
|
|
|
|
{"hits", "2"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"b", "54"},
|
|
|
|
{"hits", "1"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2024-10-29 14:37:07 +00:00
|
|
|
f("top by (b) with rank as x", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"b", "3"},
|
|
|
|
{"hits", "2"},
|
|
|
|
{"x", "1"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"b", "54"},
|
|
|
|
{"hits", "1"},
|
|
|
|
{"x", "2"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
2024-06-17 10:13:18 +00:00
|
|
|
f("top by (hits)", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"hits", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"hits", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"hits", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"hits", "3"},
|
|
|
|
{"hitss", "2"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"hits", "54"},
|
|
|
|
{"hitss", "1"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
f("top by (c)", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"c", ""},
|
|
|
|
{"hits", "2"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"c", "d"},
|
|
|
|
{"hits", "1"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
f("top by (d)", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"d", ""},
|
|
|
|
{"hits", "3"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
f("top by (a, b)", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
{"hits", "2"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "54"},
|
|
|
|
{"hits", "1"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
f("top 10 by (a, b)", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
{"hits", "2"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "54"},
|
|
|
|
{"hits", "1"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
f("top 1 by (a, b)", [][]Field{
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `3`},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
{"a", `2`},
|
|
|
|
{"b", `54`},
|
|
|
|
{"c", "d"},
|
|
|
|
},
|
|
|
|
}, [][]Field{
|
|
|
|
{
|
|
|
|
{"a", "2"},
|
|
|
|
{"b", "3"},
|
|
|
|
{"hits", "2"},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestPipeTopUpdateNeededFields(t *testing.T) {
|
|
|
|
f := func(s, neededFields, unneededFields, neededFieldsExpected, unneededFieldsExpected string) {
|
|
|
|
t.Helper()
|
|
|
|
expectPipeNeededFields(t, s, neededFields, unneededFields, neededFieldsExpected, unneededFieldsExpected)
|
|
|
|
}
|
|
|
|
|
|
|
|
// all the needed fields
|
|
|
|
f("top", "*", "", "*", "")
|
|
|
|
f("top by()", "*", "", "*", "")
|
|
|
|
f("top by(*)", "*", "", "*", "")
|
|
|
|
f("top by(f1,f2)", "*", "", "f1,f2", "")
|
|
|
|
f("top by(f1,f2)", "*", "", "f1,f2", "")
|
|
|
|
|
|
|
|
// all the needed fields, unneeded fields do not intersect with src
|
|
|
|
f("top by(s1, s2)", "*", "f1,f2", "s1,s2", "")
|
|
|
|
f("top", "*", "f1,f2", "*", "")
|
|
|
|
|
|
|
|
// all the needed fields, unneeded fields intersect with src
|
|
|
|
f("top by(s1, s2)", "*", "s1,f1,f2", "s1,s2", "")
|
|
|
|
f("top by(*)", "*", "s1,f1,f2", "*", "")
|
|
|
|
f("top by(s1, s2)", "*", "s1,s2,f1", "s1,s2", "")
|
|
|
|
|
|
|
|
// needed fields do not intersect with src
|
|
|
|
f("top by (s1, s2)", "f1,f2", "", "s1,s2", "")
|
|
|
|
|
|
|
|
// needed fields intersect with src
|
|
|
|
f("top by (s1, s2)", "s1,f1,f2", "", "s1,s2", "")
|
|
|
|
f("top by (*)", "s1,f1,f2", "", "*", "")
|
|
|
|
}
|