summaryrefslogtreecommitdiffstats
path: root/vendor/gopkg.in/olivere/elastic.v5/mget_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/mget_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/mget_test.go')
-rw-r--r--vendor/gopkg.in/olivere/elastic.v5/mget_test.go96
1 files changed, 96 insertions, 0 deletions
diff --git a/vendor/gopkg.in/olivere/elastic.v5/mget_test.go b/vendor/gopkg.in/olivere/elastic.v5/mget_test.go
new file mode 100644
index 000000000..4d6bfa0c5
--- /dev/null
+++ b/vendor/gopkg.in/olivere/elastic.v5/mget_test.go
@@ -0,0 +1,96 @@
+// 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 (
+ "context"
+ "encoding/json"
+ "testing"
+)
+
+func TestMultiGet(t *testing.T) {
+ client := setupTestClientAndCreateIndex(t)
+
+ tweet1 := tweet{User: "olivere", Message: "Welcome to Golang and Elasticsearch."}
+ tweet2 := tweet{User: "olivere", Message: "Another unrelated topic."}
+ tweet3 := tweet{User: "sandrae", Message: "Cycling is fun."}
+
+ // Add some documents
+ _, err := client.Index().Index(testIndexName).Type("tweet").Id("1").BodyJson(&tweet1).Do(context.TODO())
+ if err != nil {
+ t.Fatal(err)
+ }
+
+ _, err = client.Index().Index(testIndexName).Type("tweet").Id("2").BodyJson(&tweet2).Do(context.TODO())
+ if err != nil {
+ t.Fatal(err)
+ }
+
+ _, err = client.Index().Index(testIndexName).Type("tweet").Id("3").BodyJson(&tweet3).Do(context.TODO())
+ if err != nil {
+ t.Fatal(err)
+ }
+
+ _, err = client.Flush().Index(testIndexName).Do(context.TODO())
+ if err != nil {
+ t.Fatal(err)
+ }
+
+ // Count documents
+ count, err := client.Count(testIndexName).Do(context.TODO())
+ if err != nil {
+ t.Fatal(err)
+ }
+ if count != 3 {
+ t.Errorf("expected Count = %d; got %d", 3, count)
+ }
+
+ // Get documents 1 and 3
+ res, err := client.MultiGet().
+ Add(NewMultiGetItem().Index(testIndexName).Type("tweet").Id("1")).
+ Add(NewMultiGetItem().Index(testIndexName).Type("tweet").Id("3")).
+ Do(context.TODO())
+ if err != nil {
+ t.Fatal(err)
+ }
+ if res == nil {
+ t.Fatal("expected result to be != nil; got nil")
+ }
+ if res.Docs == nil {
+ t.Fatal("expected result docs to be != nil; got nil")
+ }
+ if len(res.Docs) != 2 {
+ t.Fatalf("expected to have 2 docs; got %d", len(res.Docs))
+ }
+
+ item := res.Docs[0]
+ if item.Error != nil {
+ t.Errorf("expected no error on item 0; got %v", item.Error)
+ }
+ if item.Source == nil {
+ t.Errorf("expected Source != nil; got %v", item.Source)
+ }
+ var doc tweet
+ if err := json.Unmarshal(*item.Source, &doc); err != nil {
+ t.Fatalf("expected to unmarshal item Source; got %v", err)
+ }
+ if doc.Message != tweet1.Message {
+ t.Errorf("expected Message of first tweet to be %q; got %q", tweet1.Message, doc.Message)
+ }
+
+ item = res.Docs[1]
+ if item.Error != nil {
+ t.Errorf("expected no error on item 1; got %v", item.Error)
+ }
+ if item.Source == nil {
+ t.Errorf("expected Source != nil; got %v", item.Source)
+ }
+ if err := json.Unmarshal(*item.Source, &doc); err != nil {
+ t.Fatalf("expected to unmarshal item Source; got %v", err)
+ }
+ if doc.Message != tweet3.Message {
+ t.Errorf("expected Message of second tweet to be %q; got %q", tweet3.Message, doc.Message)
+ }
+}