package logstorage import ( "testing" ) func TestParseStatsCountSuccess(t *testing.T) { f := func(pipeStr string) { t.Helper() expectParseStatsFuncSuccess(t, pipeStr) } f(`count(*)`) f(`count(a)`) f(`count(a, b)`) } func TestParseStatsCountFailure(t *testing.T) { f := func(pipeStr string) { t.Helper() expectParseStatsFuncFailure(t, pipeStr) } f(`count`) f(`count(a b)`) f(`count(x) y`) } func TestStatsCount(t *testing.T) { f := func(pipeStr string, rows, rowsExpected [][]Field) { t.Helper() expectPipeResults(t, pipeStr, rows, rowsExpected) } f("stats count(*) as x", [][]Field{ { {"_msg", `abc`}, {"a", `2`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, }, {}, { {"a", `3`}, {"b", `54`}, }, }, [][]Field{ { {"x", "4"}, }, }) f("stats count(b) as x", [][]Field{ { {"_msg", `abc`}, {"a", `2`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, }, {}, { {"a", `3`}, {"b", `54`}, }, }, [][]Field{ { {"x", "2"}, }, }) f("stats count(a, b) as x", [][]Field{ { {"_msg", `abc`}, {"a", `2`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, }, {}, { {"aa", `3`}, {"bb", `54`}, }, }, [][]Field{ { {"x", "2"}, }, }) f("stats count(c) as x", [][]Field{ { {"_msg", `abc`}, {"a", `2`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, }, { {"a", `3`}, {"b", `54`}, }, }, [][]Field{ { {"x", "0"}, }, }) f("stats count(a) if (b:*) as x", [][]Field{ { {"_msg", `abc`}, {"a", `2`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, }, { {"b", `54`}, }, }, [][]Field{ { {"x", "1"}, }, }) f("stats by (a) count(b) as x", [][]Field{ { {"_msg", `abc`}, {"a", `1`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, }, { {"a", `3`}, {"b", `5`}, }, { {"a", `3`}, {"b", `7`}, }, }, [][]Field{ { {"a", "1"}, {"x", "1"}, }, { {"a", "3"}, {"x", "2"}, }, }) f("stats by (a) count(b) if (!c:foo) as x", [][]Field{ { {"_msg", `abc`}, {"a", `1`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, {"b", "aadf"}, {"c", "foo"}, }, { {"a", `3`}, {"b", `5`}, {"c", "bar"}, }, { {"a", `3`}, }, }, [][]Field{ { {"a", "1"}, {"x", "1"}, }, { {"a", "3"}, {"x", "1"}, }, }) f("stats by (a) count(*) as x", [][]Field{ { {"_msg", `abc`}, {"a", `1`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, {"c", "3"}, }, {}, { {"a", `3`}, {"b", `5`}, }, }, [][]Field{ { {"a", ""}, {"x", "1"}, }, { {"a", "1"}, {"x", "2"}, }, { {"a", "3"}, {"x", "1"}, }, }) f("stats by (a) count(c) as x", [][]Field{ { {"_msg", `abc`}, {"a", `1`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, }, { {"a", `3`}, {"c", `5`}, }, { {"a", `3`}, {"b", `7`}, }, }, [][]Field{ { {"a", "1"}, {"x", "0"}, }, { {"a", "3"}, {"x", "1"}, }, }) f("stats by (a) count(a, b, c) as x", [][]Field{ { {"_msg", `abc`}, {"a", `1`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, {"c", "3"}, }, { {"a", `3`}, {"b", `5`}, }, { {"foo", "bar"}, }, { {"a", `3`}, {"b", `7`}, }, }, [][]Field{ { {"a", "1"}, {"x", "2"}, }, { {"a", ""}, {"x", "0"}, }, { {"a", "3"}, {"x", "2"}, }, }) f("stats by (a, b) count(a) as x", [][]Field{ { {"_msg", `abc`}, {"a", `1`}, {"b", `3`}, }, { {"_msg", `def`}, {"a", `1`}, {"c", "3"}, }, { {"c", `3`}, {"b", `5`}, }, }, [][]Field{ { {"a", "1"}, {"b", "3"}, {"x", "1"}, }, { {"a", "1"}, {"b", ""}, {"x", "1"}, }, { {"a", ""}, {"b", "5"}, {"x", "0"}, }, }) }