summaryrefslogtreecommitdiff
path: root/internal/mapr/query_test.go
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2026-03-03 11:20:42 +0200
committerPaul Buetow <paul@buetow.org>2026-03-03 11:20:42 +0200
commit8762a54a74da48b304e49e23bd2b2eeb8f541f67 (patch)
treebba472803a19e370fcf24fe7d7c7f7b6c343f323 /internal/mapr/query_test.go
parent77661ef1c646a5ef8e6964afa5571c756d1fd31d (diff)
Add percentage and percentile mapr aggregators
Diffstat (limited to 'internal/mapr/query_test.go')
-rw-r--r--internal/mapr/query_test.go36
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)
+ }
+}