mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
12125: panic: zap.Logger is nil in Embed client
This commit is contained in:
parent
07461ecc8c
commit
701f02f90a
@ -112,7 +112,7 @@ func New(cfg Config) (*Client, error) {
|
|||||||
// service interface implementations and do not need connection management.
|
// service interface implementations and do not need connection management.
|
||||||
func NewCtxClient(ctx context.Context) *Client {
|
func NewCtxClient(ctx context.Context) *Client {
|
||||||
cctx, cancel := context.WithCancel(ctx)
|
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.
|
// NewFromURL creates a new etcdv3 client from a URL.
|
||||||
@ -125,6 +125,12 @@ func NewFromURLs(urls []string) (*Client, error) {
|
|||||||
return New(Config{Endpoints: urls})
|
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.
|
// Close shuts down the client's etcd connections.
|
||||||
func (c *Client) Close() error {
|
func (c *Client) Close() error {
|
||||||
c.cancel()
|
c.cancel()
|
||||||
|
@ -166,3 +166,16 @@ func TestCloseCtxClient(t *testing.T) {
|
|||||||
t.Errorf("failed to Close the client. %v", err)
|
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")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -29,6 +29,10 @@ import (
|
|||||||
// to the etcd server through its api/v3rpc function interfaces.
|
// to the etcd server through its api/v3rpc function interfaces.
|
||||||
func New(s *etcdserver.EtcdServer) *clientv3.Client {
|
func New(s *etcdserver.EtcdServer) *clientv3.Client {
|
||||||
c := clientv3.NewCtxClient(context.Background())
|
c := clientv3.NewCtxClient(context.Background())
|
||||||
|
lg := s.Logger()
|
||||||
|
if lg != nil {
|
||||||
|
c.WithLogger(lg)
|
||||||
|
}
|
||||||
|
|
||||||
kvc := adapter.KvServerToKvClient(v3rpc.NewQuotaKVServer(s))
|
kvc := adapter.KvServerToKvClient(v3rpc.NewQuotaKVServer(s))
|
||||||
c.KV = clientv3.NewKVFromKVClient(kvc, c)
|
c.KV = clientv3.NewKVFromKVClient(kvc, c)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user