From 8db714785dbdfcd0c7734f1f9eb8f33d0025abb5 Mon Sep 17 00:00:00 2001 From: alexvanin Date: Mon, 18 May 2020 16:23:51 +0300 Subject: [PATCH] rpc/client: handle client creation error in new wsclient Client returns error if it can't parse endpoint string. WSClient should check client error or there could be panic at `cl.cli = nil` expression. --- pkg/rpc/client/wsclient.go | 4 ++++ pkg/rpc/client/wsclient_test.go | 15 +++++++++++++++ 2 files changed, 19 insertions(+) diff --git a/pkg/rpc/client/wsclient.go b/pkg/rpc/client/wsclient.go index 115fa2a64..8bf30bf6b 100644 --- a/pkg/rpc/client/wsclient.go +++ b/pkg/rpc/client/wsclient.go @@ -71,6 +71,10 @@ const ( // connection). You need to use websocket URL for it like `ws://1.2.3.4/ws`. func NewWS(ctx context.Context, endpoint string, opts Options) (*WSClient, error) { cl, err := New(ctx, endpoint, opts) + if err != nil { + return nil, err + } + cl.cli = nil dialer := websocket.Dialer{HandshakeTimeout: opts.DialTimeout} diff --git a/pkg/rpc/client/wsclient_test.go b/pkg/rpc/client/wsclient_test.go index f60f3a978..1eebe08bd 100644 --- a/pkg/rpc/client/wsclient_test.go +++ b/pkg/rpc/client/wsclient_test.go @@ -4,6 +4,7 @@ import ( "context" "net/http" "net/http/httptest" + "strings" "testing" "time" @@ -247,3 +248,17 @@ func TestWSFilteredSubscriptions(t *testing.T) { }) } } + +func TestNewWS(t *testing.T) { + srv := initTestServer(t, "") + defer srv.Close() + + t.Run("good", func(t *testing.T) { + _, err := NewWS(context.TODO(), httpURLtoWS(srv.URL), Options{}) + require.NoError(t, err) + }) + t.Run("bad URL", func(t *testing.T) { + _, err := NewWS(context.TODO(), strings.Trim(srv.URL, "http://"), Options{}) + require.Error(t, err) + }) +}