diff options
| author | Paul Buetow <paul@buetow.org> | 2026-03-03 11:20:42 +0200 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-03-03 11:20:42 +0200 |
| commit | 8762a54a74da48b304e49e23bd2b2eeb8f541f67 (patch) | |
| tree | bba472803a19e370fcf24fe7d7c7f7b6c343f323 /internal/mapr/query_test.go | |
| parent | 77661ef1c646a5ef8e6964afa5571c756d1fd31d (diff) | |
Add percentage and percentile mapr aggregators
Diffstat (limited to 'internal/mapr/query_test.go')
| -rw-r--r-- | internal/mapr/query_test.go | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/internal/mapr/query_test.go b/internal/mapr/query_test.go index f37b8d4..4207fe7 100644 --- a/internal/mapr/query_test.go +++ b/internal/mapr/query_test.go @@ -292,3 +292,39 @@ func TestQuotedSelectCondition(t *testing.T) { "'select' clause but got '%v': %s\n%v", q.Select[3].Operation, queryStr, q) } } + +func TestParseQueryPercentageAndPercentile(t *testing.T) { + queryStr := "select percentage($value),percentile($value) from stats group by $host order by percentile($value)" + + q, err := NewQuery(queryStr) + if err != nil { + t.Errorf("Query parse error: %s\n%v: %v", queryStr, q, err) + } + if len(q.Select) != 2 { + t.Fatalf("Expected two elements in 'select' clause but got '%v': %s\n%v", + q.Select, queryStr, q) + } + + if q.Select[0].Operation != Percentage { + t.Errorf("Expected 'percentage' as first select aggregation but got '%v': %s\n%v", + q.Select[0].Operation, queryStr, q) + } + if q.Select[0].FieldStorage != "percentage($value)" { + t.Errorf("Expected percentage field storage but got '%v': %s\n%v", + q.Select[0].FieldStorage, queryStr, q) + } + + if q.Select[1].Operation != Percentile { + t.Errorf("Expected 'percentile' as second select aggregation but got '%v': %s\n%v", + q.Select[1].Operation, queryStr, q) + } + if q.Select[1].FieldStorage != "percentile($value)" { + t.Errorf("Expected percentile field storage but got '%v': %s\n%v", + q.Select[1].FieldStorage, queryStr, q) + } + + if q.OrderBy != "percentile($value)" { + t.Errorf("Expected order by percentile($value) but got '%v': %s\n%v", + q.OrderBy, queryStr, q) + } +} |
