summaryrefslogtreecommitdiffstats
path: root/vendor/gopkg.in/olivere/elastic.v5/search_queries_nested_test.go
diff options
context:
space:
mode:
authorGeorge Goldberg <george@gberg.me>2017-05-09 14:13:24 +0100
committerJoram Wilander <jwawilander@gmail.com>2017-05-09 08:13:24 -0500
commit622998add12734a6c2b5d79918338a4d6dca7ce6 (patch)
tree198d507eb04c5684d5b191b17ed957f02f2df6ed /vendor/gopkg.in/olivere/elastic.v5/search_queries_nested_test.go
parentb25021b9129820147bf596b834d438ef218acf28 (diff)
downloadchat-622998add12734a6c2b5d79918338a4d6dca7ce6.tar.gz
chat-622998add12734a6c2b5d79918338a4d6dca7ce6.tar.bz2
chat-622998add12734a6c2b5d79918338a4d6dca7ce6.zip
PLT-6398: Add dependency on go elastic search library. (#6340)
Diffstat (limited to 'vendor/gopkg.in/olivere/elastic.v5/search_queries_nested_test.go')
-rw-r--r--vendor/gopkg.in/olivere/elastic.v5/search_queries_nested_test.go52
1 files changed, 52 insertions, 0 deletions
diff --git a/vendor/gopkg.in/olivere/elastic.v5/search_queries_nested_test.go b/vendor/gopkg.in/olivere/elastic.v5/search_queries_nested_test.go
new file mode 100644
index 000000000..af9740553
--- /dev/null
+++ b/vendor/gopkg.in/olivere/elastic.v5/search_queries_nested_test.go
@@ -0,0 +1,52 @@
+// 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 TestNestedQuery(t *testing.T) {
+ bq := NewBoolQuery()
+ bq = bq.Must(NewTermQuery("obj1.name", "blue"))
+ bq = bq.Must(NewRangeQuery("obj1.count").Gt(5))
+ q := NewNestedQuery("obj1", bq).QueryName("qname")
+ 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 := `{"nested":{"_name":"qname","path":"obj1","query":{"bool":{"must":[{"term":{"obj1.name":"blue"}},{"range":{"obj1.count":{"from":5,"include_lower":false,"include_upper":true,"to":null}}}]}}}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}
+
+func TestNestedQueryWithInnerHit(t *testing.T) {
+ bq := NewBoolQuery()
+ bq = bq.Must(NewTermQuery("obj1.name", "blue"))
+ bq = bq.Must(NewRangeQuery("obj1.count").Gt(5))
+ q := NewNestedQuery("obj1", bq)
+ q = q.QueryName("qname")
+ q = q.InnerHit(NewInnerHit().Name("comments").Query(NewTermQuery("user", "olivere")))
+ 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 := `{"nested":{"_name":"qname","inner_hits":{"name":"comments","query":{"term":{"user":"olivere"}}},"path":"obj1","query":{"bool":{"must":[{"term":{"obj1.name":"blue"}},{"range":{"obj1.count":{"from":5,"include_lower":false,"include_upper":true,"to":null}}}]}}}}`
+ if got != expected {
+ t.Errorf("expected\n%s\n,got:\n%s", expected, got)
+ }
+}