123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- // 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 TestGeoBoundingBoxQueryIncomplete(t *testing.T) {
- q := NewGeoBoundingBoxQuery("pin.location")
- q = q.TopLeft(40.73, -74.1)
- // no bottom and no right here
- q = q.Type("memory")
- src, err := q.Source()
- if err == nil {
- t.Fatal("expected error")
- }
- if src != nil {
- t.Fatal("expected empty source")
- }
- }
- func TestGeoBoundingBoxQuery(t *testing.T) {
- q := NewGeoBoundingBoxQuery("pin.location")
- q = q.TopLeft(40.73, -74.1)
- q = q.BottomRight(40.01, -71.12)
- q = q.Type("memory")
- 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_bounding_box":{"pin.location":{"bottom_right":[-71.12,40.01],"top_left":[-74.1,40.73]},"type":"memory"}}`
- if got != expected {
- t.Errorf("expected\n%s\n,got:\n%s", expected, got)
- }
- }
- func TestGeoBoundingBoxQueryWithGeoPoint(t *testing.T) {
- q := NewGeoBoundingBoxQuery("pin.location")
- q = q.TopLeftFromGeoPoint(GeoPointFromLatLon(40.73, -74.1))
- q = q.BottomRightFromGeoPoint(GeoPointFromLatLon(40.01, -71.12))
- 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_bounding_box":{"pin.location":{"bottom_right":[-71.12,40.01],"top_left":[-74.1,40.73]}}}`
- if got != expected {
- t.Errorf("expected\n%s\n,got:\n%s", expected, got)
- }
- }
|