| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | // Copyright 2013 Belogik. All rights reserved.
 | 
					
						
							|  |  |  | // Use of this source code is governed by a BSD-style
 | 
					
						
							|  |  |  | // license that can be found in the LICENSE file.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package goes | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	. "launchpad.net/gocheck" | 
					
						
							| 
									
										
										
										
											2014-05-30 05:01:39 +08:00
										 |  |  | 	"net/http" | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	"net/url" | 
					
						
							|  |  |  | 	"os" | 
					
						
							| 
									
										
										
										
											2014-11-13 00:35:37 +08:00
										 |  |  | 	"strings" | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	"testing" | 
					
						
							|  |  |  | 	"time" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var ( | 
					
						
							|  |  |  | 	ES_HOST = "localhost" | 
					
						
							|  |  |  | 	ES_PORT = "9200" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Hook up gocheck into the gotest runner.
 | 
					
						
							|  |  |  | func Test(t *testing.T) { TestingT(t) } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type GoesTestSuite struct{} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | var _ = Suite(&GoesTestSuite{}) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) SetUpTest(c *C) { | 
					
						
							|  |  |  | 	h := os.Getenv("TEST_ELASTICSEARCH_HOST") | 
					
						
							|  |  |  | 	if h != "" { | 
					
						
							|  |  |  | 		ES_HOST = h | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	p := os.Getenv("TEST_ELASTICSEARCH_PORT") | 
					
						
							|  |  |  | 	if p != "" { | 
					
						
							|  |  |  | 		ES_PORT = p | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestNewConnection(c *C) { | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							| 
									
										
										
										
											2014-05-30 05:01:39 +08:00
										 |  |  | 	c.Assert(conn, DeepEquals, &Connection{ES_HOST, ES_PORT, http.DefaultClient}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestWithClient(c *C) { | 
					
						
							|  |  |  | 	tr := &http.Transport{ | 
					
						
							|  |  |  | 		DisableCompression:    true, | 
					
						
							|  |  |  | 		ResponseHeaderTimeout: 1 * time.Second, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	cl := &http.Client{ | 
					
						
							|  |  |  | 		Transport: tr, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT).WithClient(cl) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(conn, DeepEquals, &Connection{ES_HOST, ES_PORT, cl}) | 
					
						
							|  |  |  | 	c.Assert(conn.Client.Transport.(*http.Transport).DisableCompression, Equals, true) | 
					
						
							|  |  |  | 	c.Assert(conn.Client.Transport.(*http.Transport).ResponseHeaderTimeout, Equals, 1*time.Second) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestUrl(c *C) { | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	r := Request{ | 
					
						
							|  |  |  | 		Conn:      conn, | 
					
						
							|  |  |  | 		Query:     "q", | 
					
						
							|  |  |  | 		IndexList: []string{"i"}, | 
					
						
							|  |  |  | 		TypeList:  []string{}, | 
					
						
							|  |  |  | 		method:    "GET", | 
					
						
							|  |  |  | 		api:       "_search", | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(r.Url(), Equals, "http://"+ES_HOST+":"+ES_PORT+"/i/_search") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	r.IndexList = []string{"a", "b"} | 
					
						
							|  |  |  | 	c.Assert(r.Url(), Equals, "http://"+ES_HOST+":"+ES_PORT+"/a,b/_search") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	r.TypeList = []string{"c", "d"} | 
					
						
							|  |  |  | 	c.Assert(r.Url(), Equals, "http://"+ES_HOST+":"+ES_PORT+"/a,b/c,d/_search") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	r.ExtraArgs = make(url.Values, 1) | 
					
						
							|  |  |  | 	r.ExtraArgs.Set("version", "1") | 
					
						
							|  |  |  | 	c.Assert(r.Url(), Equals, "http://"+ES_HOST+":"+ES_PORT+"/a,b/c,d/_search?version=1") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	r.id = "1234" | 
					
						
							|  |  |  | 	r.api = "" | 
					
						
							|  |  |  | 	c.Assert(r.Url(), Equals, "http://"+ES_HOST+":"+ES_PORT+"/a,b/c,d/1234/?version=1") | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestEsDown(c *C) { | 
					
						
							|  |  |  | 	conn := NewConnection("a.b.c.d", "1234") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	var query = map[string]interface{}{"query": "foo"} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	r := Request{ | 
					
						
							|  |  |  | 		Conn:      conn, | 
					
						
							|  |  |  | 		Query:     query, | 
					
						
							|  |  |  | 		IndexList: []string{"i"}, | 
					
						
							|  |  |  | 		method:    "GET", | 
					
						
							|  |  |  | 		api:       "_search", | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	_, err := r.Run() | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-12 01:00:54 +08:00
										 |  |  | 	c.Assert(err, ErrorMatches, "Get http://a.b.c.d:1234/i/_search:(.*)lookup a.b.c.d: no such host") | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestRunMissingIndex(c *C) { | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	var query = map[string]interface{}{"query": "foo"} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	r := Request{ | 
					
						
							|  |  |  | 		Conn:      conn, | 
					
						
							|  |  |  | 		Query:     query, | 
					
						
							|  |  |  | 		IndexList: []string{"i"}, | 
					
						
							|  |  |  | 		method:    "GET", | 
					
						
							|  |  |  | 		api:       "_search", | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	_, err := r.Run() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(err.Error(), Equals, "[404] IndexMissingException[[i] missing]") | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestCreateIndex(c *C) { | 
					
						
							|  |  |  | 	indexName := "testcreateindexgoes" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mapping := map[string]interface{}{ | 
					
						
							|  |  |  | 		"settings": map[string]interface{}{ | 
					
						
							|  |  |  | 			"index.number_of_shards":   1, | 
					
						
							|  |  |  | 			"index.number_of_replicas": 0, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		"mappings": map[string]interface{}{ | 
					
						
							|  |  |  | 			"_default_": map[string]interface{}{ | 
					
						
							|  |  |  | 				"_source": map[string]interface{}{ | 
					
						
							|  |  |  | 					"enabled": false, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				"_all": map[string]interface{}{ | 
					
						
							|  |  |  | 					"enabled": false, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	resp, err := conn.CreateIndex(indexName, mapping) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	c.Assert(resp.Acknowledged, Equals, true) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestDeleteIndexInexistantIndex(c *C) { | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	resp, err := conn.DeleteIndex("foobar") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(err.Error(), Equals, "[404] IndexMissingException[[foobar] missing]") | 
					
						
							|  |  |  | 	c.Assert(resp, DeepEquals, Response{}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestDeleteIndexExistingIndex(c *C) { | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	indexName := "testdeleteindexexistingindex" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	resp, err := conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedResponse := Response{} | 
					
						
							|  |  |  | 	expectedResponse.Acknowledged = true | 
					
						
							| 
									
										
										
										
											2014-11-13 16:21:27 +08:00
										 |  |  | 	resp.Raw = nil | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(resp, DeepEquals, expectedResponse) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestRefreshIndex(c *C) { | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	indexName := "testrefreshindex" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-16 01:18:01 +08:00
										 |  |  | 	_, err = conn.RefreshIndex(indexName) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-21 18:06:24 +08:00
										 |  |  | func (s *GoesTestSuite) TestOptimize(c *C) { | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	indexName := "testoptimize" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// we must wait for a bit otherwise ES crashes
 | 
					
						
							|  |  |  | 	time.Sleep(1 * time.Second) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err := conn.Optimize([]string{indexName}, url.Values{"max_num_segments" : []string{"1"}}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(response.All.Indices[indexName].Primaries["docs"].Count, Equals, 0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | func (s *GoesTestSuite) TestBulkSend(c *C) { | 
					
						
							|  |  |  | 	indexName := "testbulkadd" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	tweets := []Document{ | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 			Id:          "123", | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:37 +08:00
										 |  |  | 			Index:       indexName, | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_INDEX, | 
					
						
							|  |  |  | 			Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 				"user":    "foo", | 
					
						
							|  |  |  | 				"message": "some foo message", | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 			Id:          nil, | 
					
						
							|  |  |  | 			Index:       indexName, | 
					
						
							|  |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_INDEX, | 
					
						
							|  |  |  | 			Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 				"user":    "bar", | 
					
						
							|  |  |  | 				"message": "some bar message", | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, nil) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:37 +08:00
										 |  |  | 	response, err := conn.BulkSend(tweets) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	i := Item{ | 
					
						
							|  |  |  | 		Id:      "123", | 
					
						
							|  |  |  | 		Type:    docType, | 
					
						
							|  |  |  | 		Version: 1, | 
					
						
							|  |  |  | 		Index:   indexName, | 
					
						
							| 
									
										
										
										
											2014-10-13 15:43:58 +08:00
										 |  |  | 		Status:  201, //201 for indexing ( https://issues.apache.org/jira/browse/CONNECTORS-634 )
 | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	c.Assert(response.Items[0][BULK_COMMAND_INDEX], Equals, i) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.RefreshIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	var query = map[string]interface{}{ | 
					
						
							|  |  |  | 		"query": map[string]interface{}{ | 
					
						
							|  |  |  | 			"match_all": map[string]interface{}{}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-07 20:57:37 +08:00
										 |  |  | 	searchResults, err := conn.Search(query, []string{indexName}, []string{}, url.Values{}) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	var expectedTotal uint64 = 2 | 
					
						
							|  |  |  | 	c.Assert(searchResults.Hits.Total, Equals, expectedTotal) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	extraDocId := "" | 
					
						
							|  |  |  | 	checked := 0 | 
					
						
							|  |  |  | 	for _, hit := range searchResults.Hits.Hits { | 
					
						
							|  |  |  | 		if hit.Source["user"] == "foo" { | 
					
						
							|  |  |  | 			c.Assert(hit.Id, Equals, "123") | 
					
						
							|  |  |  | 			checked++ | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if hit.Source["user"] == "bar" { | 
					
						
							|  |  |  | 			c.Assert(len(hit.Id) > 0, Equals, true) | 
					
						
							|  |  |  | 			extraDocId = hit.Id | 
					
						
							|  |  |  | 			checked++ | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	c.Assert(checked, Equals, 2) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	docToDelete := []Document{ | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 			Id:          "123", | 
					
						
							|  |  |  | 			Index:       indexName, | 
					
						
							|  |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_DELETE, | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 			Id:          extraDocId, | 
					
						
							|  |  |  | 			Index:       indexName, | 
					
						
							|  |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_DELETE, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:37 +08:00
										 |  |  | 	response, err = conn.BulkSend(docToDelete) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	i = Item{ | 
					
						
							|  |  |  | 		Id:      "123", | 
					
						
							|  |  |  | 		Type:    docType, | 
					
						
							|  |  |  | 		Version: 2, | 
					
						
							|  |  |  | 		Index:   indexName, | 
					
						
							| 
									
										
										
										
											2014-10-13 15:43:58 +08:00
										 |  |  | 		Status:  200, //200 for updates
 | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	c.Assert(response.Items[0][BULK_COMMAND_DELETE], Equals, i) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.RefreshIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-07 20:57:37 +08:00
										 |  |  | 	searchResults, err = conn.Search(query, []string{indexName}, []string{}, url.Values{}) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedTotal = 0 | 
					
						
							|  |  |  | 	c.Assert(searchResults.Hits.Total, Equals, expectedTotal) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-18 12:54:31 +08:00
										 |  |  | func (s *GoesTestSuite) TestStats(c *C) { | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							| 
									
										
										
										
											2013-06-18 14:04:52 +08:00
										 |  |  | 	indexName := "teststats" | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-18 14:04:52 +08:00
										 |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// we must wait for a bit otherwise ES crashes
 | 
					
						
							|  |  |  | 	time.Sleep(1 * time.Second) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-18 14:04:52 +08:00
										 |  |  | 	response, err := conn.Stats([]string{indexName}, url.Values{}) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(response.All.Indices[indexName].Primaries["docs"].Count, Equals, 0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-18 04:25:25 +08:00
										 |  |  | func (s *GoesTestSuite) TestIndexWithFieldsInStruct(c *C) { | 
					
						
							|  |  |  | 	indexName := "testindexwithfieldsinstruct" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 	docId := "1234" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Id:    docId, | 
					
						
							|  |  |  | 		Fields: struct { | 
					
						
							|  |  |  | 			user    string | 
					
						
							|  |  |  | 			message string | 
					
						
							|  |  |  | 		}{ | 
					
						
							|  |  |  | 			"foo", | 
					
						
							|  |  |  | 			"bar", | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	extraArgs := make(url.Values, 1) | 
					
						
							|  |  |  | 	extraArgs.Set("ttl", "86400000") | 
					
						
							|  |  |  | 	response, err := conn.Index(d, extraArgs) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedResponse := Response{ | 
					
						
							|  |  |  | 		Index:   indexName, | 
					
						
							|  |  |  | 		Id:      docId, | 
					
						
							|  |  |  | 		Type:    docType, | 
					
						
							|  |  |  | 		Version: 1, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-13 16:21:27 +08:00
										 |  |  | 	response.Raw = nil | 
					
						
							| 
									
										
										
										
											2014-08-18 04:25:25 +08:00
										 |  |  | 	c.Assert(response, DeepEquals, expectedResponse) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestIndexWithFieldsNotInMapOrStruct(c *C) { | 
					
						
							|  |  |  | 	indexName := "testindexwithfieldsnotinmaporstruct" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 	docId := "1234" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index:  indexName, | 
					
						
							|  |  |  | 		Type:   docType, | 
					
						
							|  |  |  | 		Id:     docId, | 
					
						
							|  |  |  | 		Fields: "test", | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	extraArgs := make(url.Values, 1) | 
					
						
							|  |  |  | 	extraArgs.Set("ttl", "86400000") | 
					
						
							|  |  |  | 	_, err = conn.Index(d, extraArgs) | 
					
						
							|  |  |  | 	c.Assert(err, Not(IsNil)) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | func (s *GoesTestSuite) TestIndexIdDefined(c *C) { | 
					
						
							|  |  |  | 	indexName := "testindexiddefined" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 	docId := "1234" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Id:    docId, | 
					
						
							|  |  |  | 		Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 			"user":    "foo", | 
					
						
							|  |  |  | 			"message": "bar", | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	extraArgs := make(url.Values, 1) | 
					
						
							|  |  |  | 	extraArgs.Set("ttl", "86400000") | 
					
						
							|  |  |  | 	response, err := conn.Index(d, extraArgs) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedResponse := Response{ | 
					
						
							|  |  |  | 		Index:   indexName, | 
					
						
							|  |  |  | 		Id:      docId, | 
					
						
							|  |  |  | 		Type:    docType, | 
					
						
							|  |  |  | 		Version: 1, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-13 16:21:27 +08:00
										 |  |  | 	response.Raw = nil | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(response, DeepEquals, expectedResponse) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestIndexIdNotDefined(c *C) { | 
					
						
							|  |  |  | 	indexName := "testindexidnotdefined" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 			"user":    "foo", | 
					
						
							|  |  |  | 			"message": "bar", | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err := conn.Index(d, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(response.Index, Equals, indexName) | 
					
						
							|  |  |  | 	c.Assert(response.Type, Equals, docType) | 
					
						
							|  |  |  | 	c.Assert(response.Version, Equals, 1) | 
					
						
							|  |  |  | 	c.Assert(response.Id != "", Equals, true) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestDelete(c *C) { | 
					
						
							|  |  |  | 	indexName := "testdelete" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 	docId := "1234" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Id:    docId, | 
					
						
							|  |  |  | 		Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 			"user": "foo", | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.Index(d, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err := conn.Delete(d, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedResponse := Response{ | 
					
						
							|  |  |  | 		Found: true, | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Id:    docId, | 
					
						
							|  |  |  | 		// XXX : even after a DELETE the version number seems to be incremented
 | 
					
						
							|  |  |  | 		Version: 2, | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-11-13 16:21:27 +08:00
										 |  |  | 	response.Raw = nil | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(response, DeepEquals, expectedResponse) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err = conn.Delete(d, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedResponse = Response{ | 
					
						
							|  |  |  | 		Found: false, | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Id:    docId, | 
					
						
							|  |  |  | 		// XXX : even after a DELETE the version number seems to be incremented
 | 
					
						
							|  |  |  | 		Version: 3, | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-11-13 16:21:27 +08:00
										 |  |  | 	response.Raw = nil | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(response, DeepEquals, expectedResponse) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 04:49:57 +08:00
										 |  |  | func (s *GoesTestSuite) TestDeleteByQuery(c *C) { | 
					
						
							|  |  |  | 	indexName := "testdeletebyquery" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 	docId := "1234" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Id:    docId, | 
					
						
							|  |  |  | 		Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 			"user": "foo", | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.Index(d, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.RefreshIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	query := map[string]interface{}{ | 
					
						
							|  |  |  | 		"query": map[string]interface{}{ | 
					
						
							|  |  |  | 			"bool": map[string]interface{}{ | 
					
						
							|  |  |  | 				"must": []map[string]interface{}{ | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						"match_all": map[string]interface{}{}, | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	//should be 1 doc before delete by query
 | 
					
						
							|  |  |  | 	response, err := conn.Search(query, []string{indexName}, []string{docType}, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	c.Assert(response.Hits.Total, Equals, uint64(1)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err = conn.Query(query, []string{indexName}, []string{docType}, "DELETE", url.Values{}) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedResponse := Response{ | 
					
						
							|  |  |  | 		Found:   false, | 
					
						
							|  |  |  | 		Index:   "", | 
					
						
							|  |  |  | 		Type:    "", | 
					
						
							|  |  |  | 		Id:      "", | 
					
						
							|  |  |  | 		Version: 0, | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-11-13 16:21:27 +08:00
										 |  |  | 	response.Raw = nil | 
					
						
							| 
									
										
										
										
											2014-09-12 04:49:57 +08:00
										 |  |  | 	c.Assert(response, DeepEquals, expectedResponse) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	//should be 0 docs after delete by query
 | 
					
						
							|  |  |  | 	response, err = conn.Search(query, []string{indexName}, []string{docType}, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	c.Assert(response.Hits.Total, Equals, uint64(0)) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | func (s *GoesTestSuite) TestGet(c *C) { | 
					
						
							|  |  |  | 	indexName := "testget" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 	docId := "111" | 
					
						
							|  |  |  | 	source := map[string]interface{}{ | 
					
						
							|  |  |  | 		"f1": "foo", | 
					
						
							|  |  |  | 		"f2": "foo", | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index:  indexName, | 
					
						
							|  |  |  | 		Type:   docType, | 
					
						
							|  |  |  | 		Id:     docId, | 
					
						
							|  |  |  | 		Fields: source, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.Index(d, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err := conn.Get(indexName, docType, docId, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedResponse := Response{ | 
					
						
							|  |  |  | 		Index:   indexName, | 
					
						
							|  |  |  | 		Type:    docType, | 
					
						
							|  |  |  | 		Id:      docId, | 
					
						
							|  |  |  | 		Version: 1, | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:55 +08:00
										 |  |  | 		Found:   true, | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 		Source:  source, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-13 16:21:27 +08:00
										 |  |  | 	response.Raw = nil | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(response, DeepEquals, expectedResponse) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	fields := make(url.Values, 1) | 
					
						
							|  |  |  | 	fields.Set("fields", "f1") | 
					
						
							|  |  |  | 	response, err = conn.Get(indexName, docType, docId, fields) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedResponse = Response{ | 
					
						
							|  |  |  | 		Index:   indexName, | 
					
						
							|  |  |  | 		Type:    docType, | 
					
						
							|  |  |  | 		Id:      docId, | 
					
						
							|  |  |  | 		Version: 1, | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:55 +08:00
										 |  |  | 		Found:   true, | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 		Fields: map[string]interface{}{ | 
					
						
							| 
									
										
										
										
											2014-03-16 01:18:01 +08:00
										 |  |  | 			"f1": []interface{}{"foo"}, | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-13 16:21:27 +08:00
										 |  |  | 	response.Raw = nil | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 	c.Assert(response, DeepEquals, expectedResponse) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestSearch(c *C) { | 
					
						
							|  |  |  | 	indexName := "testsearch" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 	docId := "1234" | 
					
						
							|  |  |  | 	source := map[string]interface{}{ | 
					
						
							|  |  |  | 		"user":    "foo", | 
					
						
							|  |  |  | 		"message": "bar", | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							| 
									
										
										
										
											2013-06-23 13:18:32 +08:00
										 |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index:  indexName, | 
					
						
							|  |  |  | 		Type:   docType, | 
					
						
							|  |  |  | 		Id:     docId, | 
					
						
							|  |  |  | 		Fields: source, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.Index(d, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.RefreshIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// I can feel my eyes bleeding
 | 
					
						
							|  |  |  | 	query := map[string]interface{}{ | 
					
						
							|  |  |  | 		"query": map[string]interface{}{ | 
					
						
							|  |  |  | 			"bool": map[string]interface{}{ | 
					
						
							|  |  |  | 				"must": []map[string]interface{}{ | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 					{ | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 						"match_all": map[string]interface{}{}, | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-05-07 20:57:37 +08:00
										 |  |  | 	response, err := conn.Search(query, []string{indexName}, []string{docType}, url.Values{}) | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	expectedHits := Hits{ | 
					
						
							|  |  |  | 		Total:    1, | 
					
						
							|  |  |  | 		MaxScore: 1.0, | 
					
						
							|  |  |  | 		Hits: []Hit{ | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 			{ | 
					
						
							| 
									
										
										
										
											2013-06-15 14:18:48 +08:00
										 |  |  | 				Index:  indexName, | 
					
						
							|  |  |  | 				Type:   docType, | 
					
						
							|  |  |  | 				Id:     docId, | 
					
						
							|  |  |  | 				Score:  1.0, | 
					
						
							|  |  |  | 				Source: source, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(response.Hits, DeepEquals, expectedHits) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2013-06-23 14:59:23 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestIndexStatus(c *C) { | 
					
						
							|  |  |  | 	indexName := "testindexstatus" | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mapping := map[string]interface{}{ | 
					
						
							|  |  |  | 		"settings": map[string]interface{}{ | 
					
						
							|  |  |  | 			"index.number_of_shards":   1, | 
					
						
							|  |  |  | 			"index.number_of_replicas": 1, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, mapping) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// gives ES some time to do its job
 | 
					
						
							|  |  |  | 	time.Sleep(1 * time.Second) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-27 02:55:47 +08:00
										 |  |  | 	response, err := conn.IndexStatus([]string{"testindexstatus"}) | 
					
						
							| 
									
										
										
										
											2013-06-23 14:59:23 +08:00
										 |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expectedShards := Shard{Total: 2, Successful: 1, Failed: 0} | 
					
						
							|  |  |  | 	c.Assert(response.Shards, Equals, expectedShards) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-02 02:48:10 +08:00
										 |  |  | 	primarySizeInBytes := response.Indices[indexName].Index["primary_size_in_bytes"].(float64) | 
					
						
							|  |  |  | 	sizeInBytes := response.Indices[indexName].Index["size_in_bytes"].(float64) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(primarySizeInBytes > 0, Equals, true) | 
					
						
							|  |  |  | 	c.Assert(sizeInBytes > 0, Equals, true) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-23 14:59:23 +08:00
										 |  |  | 	expectedIndices := map[string]IndexStatus{ | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		indexName: { | 
					
						
							| 
									
										
										
										
											2013-06-23 14:59:23 +08:00
										 |  |  | 			Index: map[string]interface{}{ | 
					
						
							| 
									
										
										
										
											2014-07-02 02:48:10 +08:00
										 |  |  | 				"primary_size_in_bytes": primarySizeInBytes, | 
					
						
							|  |  |  | 				"size_in_bytes":         sizeInBytes, | 
					
						
							| 
									
										
										
										
											2013-06-23 14:59:23 +08:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 			Translog: map[string]uint64{ | 
					
						
							|  |  |  | 				"operations": 0, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			Docs: map[string]uint64{ | 
					
						
							|  |  |  | 				"num_docs":     0, | 
					
						
							|  |  |  | 				"max_doc":      0, | 
					
						
							|  |  |  | 				"deleted_docs": 0, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			Merges: map[string]interface{}{ | 
					
						
							|  |  |  | 				"current":               float64(0), | 
					
						
							|  |  |  | 				"current_docs":          float64(0), | 
					
						
							|  |  |  | 				"current_size_in_bytes": float64(0), | 
					
						
							|  |  |  | 				"total":                 float64(0), | 
					
						
							|  |  |  | 				"total_time_in_millis":  float64(0), | 
					
						
							|  |  |  | 				"total_docs":            float64(0), | 
					
						
							|  |  |  | 				"total_size_in_bytes":   float64(0), | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			Refresh: map[string]interface{}{ | 
					
						
							|  |  |  | 				"total":                float64(1), | 
					
						
							|  |  |  | 				"total_time_in_millis": float64(0), | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			Flush: map[string]interface{}{ | 
					
						
							|  |  |  | 				"total":                float64(0), | 
					
						
							|  |  |  | 				"total_time_in_millis": float64(0), | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(response.Indices, DeepEquals, expectedIndices) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-01-10 21:12:33 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestScroll(c *C) { | 
					
						
							|  |  |  | 	indexName := "testscroll" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	tweets := []Document{ | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2014-01-10 21:12:33 +08:00
										 |  |  | 			Id:          nil, | 
					
						
							|  |  |  | 			Index:       indexName, | 
					
						
							|  |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_INDEX, | 
					
						
							|  |  |  | 			Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 				"user":    "foo", | 
					
						
							|  |  |  | 				"message": "some foo message", | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2014-01-10 21:12:33 +08:00
										 |  |  | 			Id:          nil, | 
					
						
							|  |  |  | 			Index:       indexName, | 
					
						
							|  |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_INDEX, | 
					
						
							|  |  |  | 			Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 				"user":    "bar", | 
					
						
							|  |  |  | 				"message": "some bar message", | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2014-01-10 21:12:33 +08:00
										 |  |  | 			Id:          nil, | 
					
						
							|  |  |  | 			Index:       indexName, | 
					
						
							|  |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_INDEX, | 
					
						
							|  |  |  | 			Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 				"user":    "foo", | 
					
						
							|  |  |  | 				"message": "another foo message", | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mapping := map[string]interface{}{ | 
					
						
							|  |  |  | 		"settings": map[string]interface{}{ | 
					
						
							|  |  |  | 			"index.number_of_shards":   1, | 
					
						
							|  |  |  | 			"index.number_of_replicas": 0, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, mapping) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:37 +08:00
										 |  |  | 	_, err = conn.BulkSend(tweets) | 
					
						
							| 
									
										
										
										
											2014-01-10 21:12:33 +08:00
										 |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.RefreshIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	query := map[string]interface{}{ | 
					
						
							|  |  |  | 		"query": map[string]interface{}{ | 
					
						
							|  |  |  | 			"filtered": map[string]interface{}{ | 
					
						
							|  |  |  | 				"filter": map[string]interface{}{ | 
					
						
							|  |  |  | 					"term": map[string]interface{}{ | 
					
						
							|  |  |  | 						"user": "foo", | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	scan, err := conn.Scan(query, []string{indexName}, []string{docType}, "1m", 1) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	c.Assert(len(scan.ScrollId) > 0, Equals, true) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	searchResults, err := conn.Scroll(scan.ScrollId, "1m") | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// some data in first chunk
 | 
					
						
							|  |  |  | 	c.Assert(searchResults.Hits.Total, Equals, uint64(2)) | 
					
						
							|  |  |  | 	c.Assert(len(searchResults.ScrollId) > 0, Equals, true) | 
					
						
							|  |  |  | 	c.Assert(len(searchResults.Hits.Hits), Equals, 1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	searchResults, err = conn.Scroll(searchResults.ScrollId, "1m") | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// more data in second chunk
 | 
					
						
							|  |  |  | 	c.Assert(searchResults.Hits.Total, Equals, uint64(2)) | 
					
						
							|  |  |  | 	c.Assert(len(searchResults.ScrollId) > 0, Equals, true) | 
					
						
							|  |  |  | 	c.Assert(len(searchResults.Hits.Hits), Equals, 1) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	searchResults, err = conn.Scroll(searchResults.ScrollId, "1m") | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// nothing in third chunk
 | 
					
						
							|  |  |  | 	c.Assert(searchResults.Hits.Total, Equals, uint64(2)) | 
					
						
							|  |  |  | 	c.Assert(len(searchResults.ScrollId) > 0, Equals, true) | 
					
						
							|  |  |  | 	c.Assert(len(searchResults.Hits.Hits), Equals, 0) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestAggregations(c *C) { | 
					
						
							|  |  |  | 	indexName := "testaggs" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	tweets := []Document{ | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | 			Id:          nil, | 
					
						
							|  |  |  | 			Index:       indexName, | 
					
						
							|  |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_INDEX, | 
					
						
							|  |  |  | 			Fields: map[string]interface{}{ | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:55 +08:00
										 |  |  | 				"user":    "foo", | 
					
						
							|  |  |  | 				"message": "some foo message", | 
					
						
							|  |  |  | 				"age":     25, | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | 			Id:          nil, | 
					
						
							|  |  |  | 			Index:       indexName, | 
					
						
							|  |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_INDEX, | 
					
						
							|  |  |  | 			Fields: map[string]interface{}{ | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:55 +08:00
										 |  |  | 				"user":    "bar", | 
					
						
							|  |  |  | 				"message": "some bar message", | 
					
						
							|  |  |  | 				"age":     30, | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-18 04:26:17 +08:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | 			Id:          nil, | 
					
						
							|  |  |  | 			Index:       indexName, | 
					
						
							|  |  |  | 			Type:        docType, | 
					
						
							|  |  |  | 			BulkCommand: BULK_COMMAND_INDEX, | 
					
						
							|  |  |  | 			Fields: map[string]interface{}{ | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:55 +08:00
										 |  |  | 				"user":    "foo", | 
					
						
							|  |  |  | 				"message": "another foo message", | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mapping := map[string]interface{}{ | 
					
						
							|  |  |  | 		"settings": map[string]interface{}{ | 
					
						
							|  |  |  | 			"index.number_of_shards":   1, | 
					
						
							|  |  |  | 			"index.number_of_replicas": 0, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, mapping) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:37 +08:00
										 |  |  | 	_, err = conn.BulkSend(tweets) | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err = conn.RefreshIndex(indexName) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	query := map[string]interface{}{ | 
					
						
							|  |  |  | 		"aggs": map[string]interface{}{ | 
					
						
							|  |  |  | 			"user": map[string]interface{}{ | 
					
						
							|  |  |  | 				"terms": map[string]interface{}{ | 
					
						
							|  |  |  | 					"field": "user", | 
					
						
							|  |  |  | 					"order": map[string]interface{}{ | 
					
						
							|  |  |  | 						"_term": "asc", | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				"aggs": map[string]interface{}{ | 
					
						
							|  |  |  | 					"age": map[string]interface{}{ | 
					
						
							|  |  |  | 						"stats": map[string]interface{}{ | 
					
						
							|  |  |  | 							"field": "age", | 
					
						
							|  |  |  | 						}, | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 			"age": map[string]interface{}{ | 
					
						
							|  |  |  | 				"stats": map[string]interface{}{ | 
					
						
							|  |  |  | 					"field": "age", | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-07 20:57:37 +08:00
										 |  |  | 	resp, err := conn.Search(query, []string{indexName}, []string{docType}, url.Values{}) | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	user, ok := resp.Aggregations["user"] | 
					
						
							|  |  |  | 	c.Assert(ok, Equals, true) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(len(user.Buckets()), Equals, 2) | 
					
						
							|  |  |  | 	c.Assert(user.Buckets()[0].Key(), Equals, "bar") | 
					
						
							|  |  |  | 	c.Assert(user.Buckets()[1].Key(), Equals, "foo") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	barAge := user.Buckets()[0].Aggregation("age") | 
					
						
							|  |  |  | 	c.Assert(barAge["count"], Equals, 1.0) | 
					
						
							|  |  |  | 	c.Assert(barAge["sum"], Equals, 30.0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	fooAge := user.Buckets()[1].Aggregation("age") | 
					
						
							|  |  |  | 	c.Assert(fooAge["count"], Equals, 1.0) | 
					
						
							|  |  |  | 	c.Assert(fooAge["sum"], Equals, 25.0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	age, ok := resp.Aggregations["age"] | 
					
						
							|  |  |  | 	c.Assert(ok, Equals, true) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(age["count"], Equals, 2.0) | 
					
						
							| 
									
										
										
										
											2014-07-03 20:28:55 +08:00
										 |  |  | 	c.Assert(age["sum"], Equals, 25.0+30.0) | 
					
						
							| 
									
										
										
										
											2014-03-16 02:02:11 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2014-11-11 21:37:34 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestPutMapping(c *C) { | 
					
						
							|  |  |  | 	indexName := "testputmapping" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 			"user":    "foo", | 
					
						
							|  |  |  | 			"message": "bar", | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err := conn.Index(d, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mapping := map[string]interface{}{ | 
					
						
							|  |  |  | 		"tweet": map[string]interface{}{ | 
					
						
							|  |  |  | 			"properties": map[string]interface{}{ | 
					
						
							|  |  |  | 				"count": map[string]interface{}{ | 
					
						
							|  |  |  | 					"type":  "integer", | 
					
						
							|  |  |  | 					"index": "not_analyzed", | 
					
						
							|  |  |  | 					"store": true, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	response, err = conn.PutMapping("tweet", mapping, []string{indexName}) | 
					
						
							| 
									
										
										
										
											2014-11-11 21:37:34 +08:00
										 |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(response.Acknowledged, Equals, true) | 
					
						
							|  |  |  | 	c.Assert(response.TimedOut, Equals, false) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-11-11 22:37:50 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestIndicesExist(c *C) { | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	indices := []string{"testindicesexist"} | 
					
						
							| 
									
										
										
										
											2014-11-11 22:37:50 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	conn.DeleteIndex(indices[0]) | 
					
						
							| 
									
										
										
										
											2014-11-11 22:37:50 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	exists, err := conn.IndicesExist(indices) | 
					
						
							| 
									
										
										
										
											2014-11-11 22:37:50 +08:00
										 |  |  | 	c.Assert(exists, Equals, false) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	_, err = conn.CreateIndex(indices[0], map[string]interface{}{}) | 
					
						
							| 
									
										
										
										
											2014-11-11 22:37:50 +08:00
										 |  |  | 	c.Assert(err, IsNil) | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	defer conn.DeleteIndex(indices[0]) | 
					
						
							| 
									
										
										
										
											2014-11-16 06:08:40 +08:00
										 |  |  | 	time.Sleep(200 * time.Millisecond) | 
					
						
							| 
									
										
										
										
											2014-11-11 22:37:50 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	exists, err = conn.IndicesExist(indices) | 
					
						
							| 
									
										
										
										
											2014-11-11 22:37:50 +08:00
										 |  |  | 	c.Assert(exists, Equals, true) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	indices = append(indices, "nonexistent") | 
					
						
							|  |  |  | 	exists, err = conn.IndicesExist(indices) | 
					
						
							| 
									
										
										
										
											2014-11-11 22:37:50 +08:00
										 |  |  | 	c.Assert(exists, Equals, false) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-11-13 00:35:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestUpdate(c *C) { | 
					
						
							|  |  |  | 	indexName := "testupdate" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 	docId := "1234" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Id:    docId, | 
					
						
							|  |  |  | 		Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 			"user":    "foo", | 
					
						
							|  |  |  | 			"message": "bar", | 
					
						
							|  |  |  | 			"counter": 1, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	extraArgs := make(url.Values, 1) | 
					
						
							|  |  |  | 	response, err := conn.Index(d, extraArgs) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							| 
									
										
										
										
											2014-11-16 06:08:40 +08:00
										 |  |  | 	time.Sleep(200 * time.Millisecond) | 
					
						
							| 
									
										
										
										
											2014-11-13 00:35:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	expectedResponse := Response{ | 
					
						
							|  |  |  | 		Index:   indexName, | 
					
						
							|  |  |  | 		Id:      docId, | 
					
						
							|  |  |  | 		Type:    docType, | 
					
						
							|  |  |  | 		Version: 1, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-13 16:21:27 +08:00
										 |  |  | 	response.Raw = nil | 
					
						
							| 
									
										
										
										
											2014-11-13 00:35:37 +08:00
										 |  |  | 	c.Assert(response, DeepEquals, expectedResponse) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Now that we have an ordinary document indexed, try updating it
 | 
					
						
							|  |  |  | 	query := map[string]interface{}{ | 
					
						
							|  |  |  | 		"script": "ctx._source.counter += count", | 
					
						
							|  |  |  | 		"params": map[string]interface{}{ | 
					
						
							|  |  |  | 			"count": 5, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		"upsert": map[string]interface{}{ | 
					
						
							|  |  |  | 			"message": "candybar", | 
					
						
							|  |  |  | 			"user":    "admin", | 
					
						
							|  |  |  | 			"counter": 1, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err = conn.Update(d, query, extraArgs) | 
					
						
							|  |  |  | 	if err != nil && strings.Contains(err.(*SearchError).Msg, "dynamic scripting disabled") { | 
					
						
							|  |  |  | 		c.Skip("Scripting is disabled on server, skipping this test") | 
					
						
							|  |  |  | 		return | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-11-16 06:08:40 +08:00
										 |  |  | 	time.Sleep(200 * time.Millisecond) | 
					
						
							| 
									
										
										
										
											2014-11-13 00:35:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	c.Assert(err, Equals, nil) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err = conn.Get(indexName, docType, docId, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, Equals, nil) | 
					
						
							|  |  |  | 	c.Assert(response.Source["counter"], Equals, float64(6)) | 
					
						
							|  |  |  | 	c.Assert(response.Source["user"], Equals, "foo") | 
					
						
							|  |  |  | 	c.Assert(response.Source["message"], Equals, "bar") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Test another document, non-existent
 | 
					
						
							|  |  |  | 	docId = "555" | 
					
						
							|  |  |  | 	d.Id = docId | 
					
						
							|  |  |  | 	response, err = conn.Update(d, query, extraArgs) | 
					
						
							|  |  |  | 	c.Assert(err, Equals, nil) | 
					
						
							| 
									
										
										
										
											2014-11-16 06:08:40 +08:00
										 |  |  | 	time.Sleep(200 * time.Millisecond) | 
					
						
							| 
									
										
										
										
											2014-11-13 00:35:37 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	response, err = conn.Get(indexName, docType, docId, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, Equals, nil) | 
					
						
							|  |  |  | 	c.Assert(response.Source["user"], Equals, "admin") | 
					
						
							|  |  |  | 	c.Assert(response.Source["message"], Equals, "candybar") | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-11-13 16:22:11 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | func (s *GoesTestSuite) TestGetMapping(c *C) { | 
					
						
							|  |  |  | 	indexName := "testmapping" | 
					
						
							|  |  |  | 	docType := "tweet" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	conn := NewConnection(ES_HOST, ES_PORT) | 
					
						
							|  |  |  | 	// just in case
 | 
					
						
							|  |  |  | 	conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	_, err := conn.CreateIndex(indexName, map[string]interface{}{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							|  |  |  | 	defer conn.DeleteIndex(indexName) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-16 06:08:40 +08:00
										 |  |  | 	time.Sleep(300 * time.Millisecond) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	response, err := conn.GetMapping([]string{docType}, []string{indexName}) | 
					
						
							| 
									
										
										
										
											2014-11-13 16:22:11 +08:00
										 |  |  | 	c.Assert(err, Equals, nil) | 
					
						
							|  |  |  | 	c.Assert(len(response.Raw), Equals, 0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d := Document{ | 
					
						
							|  |  |  | 		Index: indexName, | 
					
						
							|  |  |  | 		Type:  docType, | 
					
						
							|  |  |  | 		Fields: map[string]interface{}{ | 
					
						
							|  |  |  | 			"user":    "foo", | 
					
						
							|  |  |  | 			"message": "bar", | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	response, err = conn.Index(d, url.Values{}) | 
					
						
							|  |  |  | 	c.Assert(err, IsNil) | 
					
						
							| 
									
										
										
										
											2014-11-16 06:08:40 +08:00
										 |  |  | 	time.Sleep(200 * time.Millisecond) | 
					
						
							| 
									
										
										
										
											2014-11-13 16:22:11 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-17 14:25:48 +08:00
										 |  |  | 	response, err = conn.GetMapping([]string{docType}, []string{indexName}) | 
					
						
							| 
									
										
										
										
											2014-11-13 16:22:11 +08:00
										 |  |  | 	c.Assert(err, Equals, nil) | 
					
						
							|  |  |  | 	c.Assert(len(response.Raw), Not(Equals), 0) | 
					
						
							|  |  |  | } |