mirror of
https://github.com/status-im/consul.git
synced 2025-02-23 02:48:19 +00:00
watch: service watcher
This commit is contained in:
parent
970c606f1a
commit
00358baa7f
@ -17,6 +17,10 @@ func init() {
|
|||||||
watchFuncFactory = map[string]watchFactory{
|
watchFuncFactory = map[string]watchFactory{
|
||||||
"key": keyWatch,
|
"key": keyWatch,
|
||||||
"keyprefix": keyPrefixWatch,
|
"keyprefix": keyPrefixWatch,
|
||||||
|
"services": servicesWatch,
|
||||||
|
"nodes": nil,
|
||||||
|
"service": nil,
|
||||||
|
"checks": nil,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -64,3 +68,17 @@ func keyPrefixWatch(params map[string][]string) (WatchFunc, error) {
|
|||||||
}
|
}
|
||||||
return fn, nil
|
return fn, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// servicesWatch is used to watch the list of available services
|
||||||
|
func servicesWatch(params map[string][]string) (WatchFunc, error) {
|
||||||
|
fn := func(p *WatchPlan) (uint64, interface{}, error) {
|
||||||
|
catalog := p.client.Catalog()
|
||||||
|
opts := consulapi.QueryOptions{WaitIndex: p.lastIndex}
|
||||||
|
services, meta, err := catalog.Services(&opts)
|
||||||
|
if err != nil {
|
||||||
|
return 0, nil, err
|
||||||
|
}
|
||||||
|
return meta.LastIndex, services, err
|
||||||
|
}
|
||||||
|
return fn, nil
|
||||||
|
}
|
||||||
|
@ -80,6 +80,9 @@ func TestKeyPrefixWatch(t *testing.T) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
v, ok := raw.(consulapi.KVPairs)
|
v, ok := raw.(consulapi.KVPairs)
|
||||||
|
if ok && v == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
if !ok || v == nil || string(v[0].Key) != "foo/bar" {
|
if !ok || v == nil || string(v[0].Key) != "foo/bar" {
|
||||||
t.Fatalf("Bad: %#v", raw)
|
t.Fatalf("Bad: %#v", raw)
|
||||||
}
|
}
|
||||||
@ -120,3 +123,46 @@ func TestKeyPrefixWatch(t *testing.T) {
|
|||||||
t.Fatalf("bad: %v", invoke)
|
t.Fatalf("bad: %v", invoke)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestServicesWatch(t *testing.T) {
|
||||||
|
if consulAddr == "" {
|
||||||
|
t.Skip()
|
||||||
|
}
|
||||||
|
plan := mustParse(t, "type:services")
|
||||||
|
invoke := 0
|
||||||
|
plan.Handler = func(idx uint64, raw interface{}) {
|
||||||
|
if invoke == 0 {
|
||||||
|
if raw == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
v, ok := raw.(map[string][]string)
|
||||||
|
if !ok || v["consul"] == nil {
|
||||||
|
t.Fatalf("Bad: %#v", raw)
|
||||||
|
}
|
||||||
|
invoke++
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
go func() {
|
||||||
|
time.Sleep(20 * time.Millisecond)
|
||||||
|
plan.Stop()
|
||||||
|
|
||||||
|
agent := plan.client.Agent()
|
||||||
|
reg := &consulapi.AgentServiceRegistration{
|
||||||
|
ID: "foo",
|
||||||
|
Name: "foo",
|
||||||
|
}
|
||||||
|
agent.ServiceRegister(reg)
|
||||||
|
time.Sleep(20 * time.Millisecond)
|
||||||
|
agent.ServiceDeregister("foo")
|
||||||
|
}()
|
||||||
|
|
||||||
|
err := plan.Run(consulAddr)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if invoke == 0 {
|
||||||
|
t.Fatalf("bad: %v", invoke)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user