summaryrefslogtreecommitdiffstats
path: root/vendor/github.com/olivere/elastic/search_queries_geo_distance_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/olivere/elastic/search_queries_geo_distance_test.go')
-rw-r--r--vendor/github.com/olivere/elastic/search_queries_geo_distance_test.go69
1 files changed, 69 insertions, 0 deletions
diff --git a/vendor/github.com/olivere/elastic/search_queries_geo_distance_test.go b/vendor/github.com/olivere/elastic/search_queries_geo_distance_test.go
new file mode 100644
index 000000000..dd169575a
--- /dev/null
+++ b/vendor/github.com/olivere/elastic/search_queries_geo_distance_test.go
@@ -0,0 +1,69 @@
+// 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 TestGeoDistanceQuery(t *testing.T) {
+ q := NewGeoDistanceQuery("pin.location")
+ q = q.Lat(40)
+ q = q.Lon(-70)
+ q = q.Distance("200km")
+ q = q.DistanceType("plane")
+ src, err := q.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 := `{"geo_distance":{"distance":"200km","distance_type":"plane","pin.location":{"lat":40,"lon":-70}}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestGeoDistanceQueryWithGeoPoint(t *testing.T) {
+ q := NewGeoDistanceQuery("pin.location")
+ q = q.GeoPoint(GeoPointFromLatLon(40, -70))
+ q = q.Distance("200km")
+ src, err := q.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 := `{"geo_distance":{"distance":"200km","pin.location":{"lat":40,"lon":-70}}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestGeoDistanceQueryWithGeoHash(t *testing.T) {
+ q := NewGeoDistanceQuery("pin.location")
+ q = q.GeoHash("drm3btev3e86")
+ q = q.Distance("12km")
+ src, err := q.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 := `{"geo_distance":{"distance":"12km","pin.location":"drm3btev3e86"}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}