summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/olivere/elastic/search_aggs_bucket_range_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/olivere/elastic/search_aggs_bucket_range_test.go')
-rw-r--r--vendor/github.com/olivere/elastic/search_aggs_bucket_range_test.go178
1 files changed, 178 insertions, 0 deletions
diff --git a/vendor/github.com/olivere/elastic/search_aggs_bucket_range_test.go b/vendor/github.com/olivere/elastic/search_aggs_bucket_range_test.go
new file mode 100644
index 000000000..17fbcecf3
--- /dev/null
+++ b/vendor/github.com/olivere/elastic/search_aggs_bucket_range_test.go
@@ -0,0 +1,178 @@
+// Copyright 2012-present Oliver Eilhard. All rights reserved.
+// Use of this source code is governed by a MIT-license.
+// See http://olivere.mit-license.org/license.txt for details.
+
+package elastic
+
+import (
+ "encoding/json"
+ "testing"
+)
+
+func TestRangeAggregation(t *testing.T) {
+ agg := NewRangeAggregation().Field("price")
+ agg = agg.AddRange(nil, 50)
+ agg = agg.AddRange(50, 100)
+ agg = agg.AddRange(100, nil)
+ src, err := agg.Source()
+ if err != nil {
+ t.Fatal(err)
+ }
+ data, err := json.Marshal(src)
+ if err != nil {
+ t.Fatalf("marshaling to JSON failed: %v", err)
+ }
+ got := string(data)
+ expected := `{"range":{"field":"price","ranges":[{"to":50},{"from":50,"to":100},{"from":100}]}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestRangeAggregationWithPointers(t *testing.T) {
+ fifty := 50
+ hundred := 100
+ agg := NewRangeAggregation().Field("price")
+ agg = agg.AddRange(nil, &fifty)
+ agg = agg.AddRange(fifty, &hundred)
+ agg = agg.AddRange(hundred, nil)
+ src, err := agg.Source()
+ if err != nil {
+ t.Fatal(err)
+ }
+ data, err := json.Marshal(src)
+ if err != nil {
+ t.Fatalf("marshaling to JSON failed: %v", err)
+ }
+ got := string(data)
+ expected := `{"range":{"field":"price","ranges":[{"to":50},{"from":50,"to":100},{"from":100}]}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestRangeAggregationWithUnbounded(t *testing.T) {
+ agg := NewRangeAggregation().Field("field_name").
+ AddUnboundedFrom(50).
+ AddRange(20, 70).
+ AddRange(70, 120).
+ AddUnboundedTo(150)
+ src, err := agg.Source()
+ if err != nil {
+ t.Fatal(err)
+ }
+ data, err := json.Marshal(src)
+ if err != nil {
+ t.Fatalf("marshaling to JSON failed: %v", err)
+ }
+ got := string(data)
+ expected := `{"range":{"field":"field_name","ranges":[{"to":50},{"from":20,"to":70},{"from":70,"to":120},{"from":150}]}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestRangeAggregationWithLtAndCo(t *testing.T) {
+ agg := NewRangeAggregation().Field("field_name").
+ Lt(50).
+ Between(20, 70).
+ Between(70, 120).
+ Gt(150)
+ src, err := agg.Source()
+ if err != nil {
+ t.Fatal(err)
+ }
+ data, err := json.Marshal(src)
+ if err != nil {
+ t.Fatalf("marshaling to JSON failed: %v", err)
+ }
+ got := string(data)
+ expected := `{"range":{"field":"field_name","ranges":[{"to":50},{"from":20,"to":70},{"from":70,"to":120},{"from":150}]}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestRangeAggregationWithKeyedFlag(t *testing.T) {
+ agg := NewRangeAggregation().Field("field_name").
+ Keyed(true).
+ Lt(50).
+ Between(20, 70).
+ Between(70, 120).
+ Gt(150)
+ src, err := agg.Source()
+ if err != nil {
+ t.Fatal(err)
+ }
+ data, err := json.Marshal(src)
+ if err != nil {
+ t.Fatalf("marshaling to JSON failed: %v", err)
+ }
+ got := string(data)
+ expected := `{"range":{"field":"field_name","keyed":true,"ranges":[{"to":50},{"from":20,"to":70},{"from":70,"to":120},{"from":150}]}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestRangeAggregationWithKeys(t *testing.T) {
+ agg := NewRangeAggregation().Field("field_name").
+ Keyed(true).
+ LtWithKey("cheap", 50).
+ BetweenWithKey("affordable", 20, 70).
+ BetweenWithKey("average", 70, 120).
+ GtWithKey("expensive", 150)
+ src, err := agg.Source()
+ if err != nil {
+ t.Fatal(err)
+ }
+ data, err := json.Marshal(src)
+ if err != nil {
+ t.Fatalf("marshaling to JSON failed: %v", err)
+ }
+ got := string(data)
+ expected := `{"range":{"field":"field_name","keyed":true,"ranges":[{"key":"cheap","to":50},{"from":20,"key":"affordable","to":70},{"from":70,"key":"average","to":120},{"from":150,"key":"expensive"}]}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestRangeAggregationWithMetaData(t *testing.T) {
+ agg := NewRangeAggregation().Field("price").Meta(map[string]interface{}{"name": "Oliver"})
+ agg = agg.AddRange(nil, 50)
+ agg = agg.AddRange(50, 100)
+ agg = agg.AddRange(100, nil)
+ src, err := agg.Source()
+ if err != nil {
+ t.Fatal(err)
+ }
+ data, err := json.Marshal(src)
+ if err != nil {
+ t.Fatalf("marshaling to JSON failed: %v", err)
+ }
+ got := string(data)
+ expected := `{"meta":{"name":"Oliver"},"range":{"field":"price","ranges":[{"to":50},{"from":50,"to":100},{"from":100}]}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestRangeAggregationWithMissing(t *testing.T) {
+ agg := NewRangeAggregation().Field("price").Missing(0)
+ agg = agg.AddRange(nil, 50)
+ agg = agg.AddRange(50, 100)
+ agg = agg.AddRange(100, nil)
+ src, err := agg.Source()
+ if err != nil {
+ t.Fatal(err)
+ }
+ data, err := json.Marshal(src)
+ if err != nil {
+ t.Fatalf("marshaling to JSON failed: %v", err)
+ }
+ got := string(data)
+ expected := `{"range":{"field":"price","missing":0,"ranges":[{"to":50},{"from":50,"to":100},{"from":100}]}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}