Browse Source

rpc: subscribe on reconnection (#689)

* rpc: subscribe on reconnection

* rpc: fix unit tests
pull/692/head
Alexandre Thibault 7 years ago
committed by Zach Ramsay
parent
commit
ce36a0111a
3 changed files with 17 additions and 2 deletions
  1. +10
    -0
      rpc/client/httpclient.go
  2. +5
    -2
      rpc/lib/client/ws_client.go
  3. +2
    -0
      rpc/lib/client/ws_client_test.go

+ 10
- 0
rpc/client/httpclient.go View File

@ -305,6 +305,14 @@ func (w *WSEvents) RemoveListener(listenerID string) {
w.EventSwitch.RemoveListener(listenerID)
}
// After being reconnected, it is necessary to redo subscription
// to server otherwise no data will be automatically received
func (w *WSEvents) redoSubscriptions() {
for event, _ := range w.evtCount {
w.subscribe(event)
}
}
// eventListener is an infinite loop pulling all websocket events
// and pushing them to the EventSwitch.
//
@ -327,6 +335,8 @@ func (w *WSEvents) eventListener() {
// before cleaning up the w.ws stuff
w.done <- true
return
case <-w.ws.ReconnectCh:
w.redoSubscriptions()
}
}
}


+ 5
- 2
rpc/lib/client/ws_client.go View File

@ -41,8 +41,9 @@ type WSClient struct {
PingPongLatencyTimer metrics.Timer
// user facing channels, closed only when the client is being stopped.
ResultsCh chan json.RawMessage
ErrorsCh chan error
ResultsCh chan json.RawMessage
ErrorsCh chan error
ReconnectCh chan bool
// internal channels
send chan types.RPCRequest // user requests
@ -139,6 +140,7 @@ func (c *WSClient) OnStart() error {
c.ResultsCh = make(chan json.RawMessage)
c.ErrorsCh = make(chan error)
c.ReconnectCh = make(chan bool)
c.send = make(chan types.RPCRequest)
// 1 additional error may come from the read/write
@ -254,6 +256,7 @@ func (c *WSClient) reconnect() error {
c.Logger.Error("failed to redial", "err", err)
} else {
c.Logger.Info("reconnected")
c.ReconnectCh <- true
return nil
}


+ 2
- 0
rpc/lib/client/ws_client_test.go View File

@ -186,6 +186,8 @@ func callWgDoneOnResult(t *testing.T, c *WSClient, wg *sync.WaitGroup) {
if err != nil {
t.Fatalf("unexpected error: %v", err)
}
case <-c.ReconnectCh:
t.Log("Reconnected")
case <-c.Quit:
return
}


Loading…
Cancel
Save