From 5df757fdd4a6fa09e2d3201e5a801a14b9b7d4d9 Mon Sep 17 00:00:00 2001 From: Simon Pasquier Date: Fri, 28 Sep 2018 11:36:43 +0200 Subject: [PATCH] zookeeper: fix panic Signed-off-by: Simon Pasquier --- discovery/manager.go | 4 ++-- discovery/zookeeper/zookeeper.go | 10 ++++----- discovery/zookeeper/zookeeper_test.go | 32 +++++++++++++++++++++++++++ 3 files changed, 39 insertions(+), 7 deletions(-) create mode 100644 discovery/zookeeper/zookeeper_test.go diff --git a/discovery/manager.go b/discovery/manager.go index bb4409fea..ee70ada2b 100644 --- a/discovery/manager.go +++ b/discovery/manager.go @@ -304,12 +304,12 @@ func (m *Manager) registerProviders(cfg sd_config.ServiceDiscoveryConfig, setNam } for _, c := range cfg.ServersetSDConfigs { add(c, func() (Discoverer, error) { - return zookeeper.NewServersetDiscovery(c, log.With(m.logger, "discovery", "zookeeper")), nil + return zookeeper.NewServersetDiscovery(c, log.With(m.logger, "discovery", "zookeeper")) }) } for _, c := range cfg.NerveSDConfigs { add(c, func() (Discoverer, error) { - return zookeeper.NewNerveDiscovery(c, log.With(m.logger, "discovery", "nerve")), nil + return zookeeper.NewNerveDiscovery(c, log.With(m.logger, "discovery", "nerve")) }) } for _, c := range cfg.EC2SDConfigs { diff --git a/discovery/zookeeper/zookeeper.go b/discovery/zookeeper/zookeeper.go index 487121457..7b5c1afc0 100644 --- a/discovery/zookeeper/zookeeper.go +++ b/discovery/zookeeper/zookeeper.go @@ -115,12 +115,12 @@ type Discovery struct { } // NewNerveDiscovery returns a new Discovery for the given Nerve config. -func NewNerveDiscovery(conf *NerveSDConfig, logger log.Logger) *Discovery { +func NewNerveDiscovery(conf *NerveSDConfig, logger log.Logger) (*Discovery, error) { return NewDiscovery(conf.Servers, time.Duration(conf.Timeout), conf.Paths, logger, parseNerveMember) } // NewServersetDiscovery returns a new Discovery for the given serverset config. -func NewServersetDiscovery(conf *ServersetSDConfig, logger log.Logger) *Discovery { +func NewServersetDiscovery(conf *ServersetSDConfig, logger log.Logger) (*Discovery, error) { return NewDiscovery(conf.Servers, time.Duration(conf.Timeout), conf.Paths, logger, parseServersetMember) } @@ -132,7 +132,7 @@ func NewDiscovery( paths []string, logger log.Logger, pf func(data []byte, path string) (model.LabelSet, error), -) *Discovery { +) (*Discovery, error) { if logger == nil { logger = log.NewNopLogger() } @@ -143,7 +143,7 @@ func NewDiscovery( c.SetLogger(treecache.NewZookeeperLogger(logger)) }) if err != nil { - return nil + return nil, err } updates := make(chan treecache.ZookeeperTreeCacheEvent) sd := &Discovery{ @@ -156,7 +156,7 @@ func NewDiscovery( for _, path := range paths { sd.treeCaches = append(sd.treeCaches, treecache.NewZookeeperTreeCache(conn, path, updates, logger)) } - return sd + return sd, nil } // Run implements the Discoverer interface. diff --git a/discovery/zookeeper/zookeeper_test.go b/discovery/zookeeper/zookeeper_test.go new file mode 100644 index 000000000..8900b2ab6 --- /dev/null +++ b/discovery/zookeeper/zookeeper_test.go @@ -0,0 +1,32 @@ +// Copyright 2018 The Prometheus Authors +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package zookeeper + +import ( + "testing" + "time" + + "github.com/prometheus/common/model" +) + +func TestNewDiscoveryError(t *testing.T) { + _, err := NewDiscovery( + []string{"unreachable.test"}, + time.Second, []string{"/"}, + nil, + func(data []byte, path string) (model.LabelSet, error) { return nil, nil }) + if err == nil { + t.Fatalf("expected error, got nil") + } +}