api: support native connect

pull/4275/head
Mitchell Hashimoto 2018-06-05 10:56:42 -07:00 committed by Jack Pearkes
parent 1830c6b308
commit 297e4f272e
2 changed files with 61 additions and 1 deletions

View File

@ -69,6 +69,7 @@ type AgentService struct {
// AgentServiceConnect represents the Connect configuration of a service. // AgentServiceConnect represents the Connect configuration of a service.
type AgentServiceConnect struct { type AgentServiceConnect struct {
Native bool
Proxy *AgentServiceConnectProxy Proxy *AgentServiceConnectProxy
} }

View File

@ -310,6 +310,65 @@ func TestAPI_CatalogConnect(t *testing.T) {
}) })
} }
func TestAPI_CatalogConnectNative(t *testing.T) {
t.Parallel()
c, s := makeClient(t)
defer s.Stop()
catalog := c.Catalog()
// Register service and proxy instances to test against.
service := &AgentService{
ID: "redis1",
Service: "redis",
Port: 8000,
Connect: &AgentServiceConnect{Native: true},
}
check := &AgentCheck{
Node: "foobar",
CheckID: "service:redis1",
Name: "Redis health check",
Notes: "Script based health check",
Status: HealthPassing,
ServiceID: "redis1",
}
reg := &CatalogRegistration{
Datacenter: "dc1",
Node: "foobar",
Address: "192.168.10.10",
Service: service,
Check: check,
}
retry.Run(t, func(r *retry.R) {
if _, err := catalog.Register(reg, nil); err != nil {
r.Fatal(err)
}
services, meta, err := catalog.Connect("redis", "", nil)
if err != nil {
r.Fatal(err)
}
if meta.LastIndex == 0 {
r.Fatalf("Bad: %v", meta)
}
if len(services) == 0 {
r.Fatalf("Bad: %v", services)
}
if services[0].Datacenter != "dc1" {
r.Fatalf("Bad datacenter: %v", services[0])
}
if services[0].ServicePort != service.Port {
r.Fatalf("Returned port should be for proxy: %v", services[0])
}
})
}
func TestAPI_CatalogNode(t *testing.T) { func TestAPI_CatalogNode(t *testing.T) {
t.Parallel() t.Parallel()
c, s := makeClient(t) c, s := makeClient(t)