/
elastictest.go
77 lines (65 loc) · 1.52 KB
/
elastictest.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
package elastictest
import (
"context"
"testing"
"github.com/ory/dockertest"
edriver "gopkg.in/olivere/elastic.v5"
"github.com/hidal-go/hidalgo/legacy/nosql"
"github.com/hidal-go/hidalgo/legacy/nosql/elastic"
"github.com/hidal-go/hidalgo/legacy/nosql/nosqltest"
)
var versions = []string{
"6.2.4",
}
func init() {
var vers []nosqltest.Version
for _, v := range versions {
vers = append(vers, nosqltest.Version{
Name: v, Factory: ElasticVersion(v),
})
}
nosqltest.Register(elastic.Name, vers...)
}
func ElasticVersion(vers string) nosqltest.Database {
return nosqltest.Database{
Traits: elastic.Traits(),
Run: func(t testing.TB) nosql.Database {
name := "docker.elastic.co/elasticsearch/elasticsearch"
pool, err := dockertest.NewPool("")
if err != nil {
t.Fatal(err)
}
cont, err := pool.Run(name, vers, nil)
if err != nil {
t.Fatal(err)
}
t.Cleanup(func() {
_ = cont.Close()
})
// Running this command might be necessary on the host:
// sysctl -w vm.max_map_count=262144
const port = "9200/tcp"
addr := "http://" + cont.GetHostPort(port)
ctx := context.Background()
err = pool.Retry(func() error {
cli, err := edriver.NewClient(edriver.SetURL(addr))
if err != nil {
return err
}
_, _, err = cli.Ping(addr).Do(ctx)
return err
})
if err != nil {
t.Fatal(err)
}
db, err := elastic.Dial(ctx, addr, "test", nil)
if err != nil {
t.Fatal(addr, err)
}
t.Cleanup(func() {
_ = db.Close()
})
return db
},
}
}