Skip to content

Commit

Permalink
Merge pull request #12131 from dissoupov/client
Browse files Browse the repository at this point in the history
12125: panic: zap.Logger is nil in Embed client
  • Loading branch information
gyuho authored Jul 13, 2020
2 parents 07461ec + 701f02f commit 4c6881f
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 1 deletion.
8 changes: 7 additions & 1 deletion clientv3/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,7 @@ func New(cfg Config) (*Client, error) {
// service interface implementations and do not need connection management.
func NewCtxClient(ctx context.Context) *Client {
cctx, cancel := context.WithCancel(ctx)
return &Client{ctx: cctx, cancel: cancel}
return &Client{ctx: cctx, cancel: cancel, lg: zap.NewNop()}
}

// NewFromURL creates a new etcdv3 client from a URL.
Expand All @@ -125,6 +125,12 @@ func NewFromURLs(urls []string) (*Client, error) {
return New(Config{Endpoints: urls})
}

// WithLogger sets a logger
func (c *Client) WithLogger(lg *zap.Logger) *Client {
c.lg = lg
return c
}

// Close shuts down the client's etcd connections.
func (c *Client) Close() error {
c.cancel()
Expand Down
13 changes: 13 additions & 0 deletions clientv3/client_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -166,3 +166,16 @@ func TestCloseCtxClient(t *testing.T) {
t.Errorf("failed to Close the client. %v", err)
}
}

func TestWithLogger(t *testing.T) {
ctx := context.Background()
c := NewCtxClient(ctx)
if c.lg == nil {
t.Errorf("unexpected nil in *zap.Logger")
}

c.WithLogger(nil)
if c.lg != nil {
t.Errorf("WithLogger should modify *zap.Logger")
}
}
4 changes: 4 additions & 0 deletions etcdserver/api/v3client/v3client.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,10 @@ import (
// to the etcd server through its api/v3rpc function interfaces.
func New(s *etcdserver.EtcdServer) *clientv3.Client {
c := clientv3.NewCtxClient(context.Background())
lg := s.Logger()
if lg != nil {
c.WithLogger(lg)
}

kvc := adapter.KvServerToKvClient(v3rpc.NewQuotaKVServer(s))
c.KV = clientv3.NewKVFromKVClient(kvc, c)
Expand Down

0 comments on commit 4c6881f

Please # to comment.