htlcswitch: modify the SendMessage method on the Peer interface to optionally block

In this commit, add a new argument to the SendMessage method to allow
callers to request that the method block until the message has been sent
on the socket to the remote peer.
This commit is contained in:
Olaoluwa Osuntokun 2018-04-04 17:36:38 -07:00
parent 6fa93a78c1
commit f53a99e18e
No known key found for this signature in database
GPG Key ID: 964EA263DD637C21
3 changed files with 7 additions and 4 deletions

@ -111,8 +111,11 @@ type ChannelLink interface {
// Peer is an interface which represents the remote lightning node inside our
// system.
type Peer interface {
// SendMessage sends message to remote peer.
SendMessage(lnwire.Message) error
// SendMessage sends message to remote peer. The second arguments
// denote if the method should block until the message has been sent to
// the remote peer. If set, this allows the caller to more strongly
// synchronize.
SendMessage(msg lnwire.Message, sync bool) error
// WipeChannel removes the channel uniquely identified by its channel
// point from all indexes associated with the peer.

@ -1392,7 +1392,7 @@ type mockPeer struct {
quit chan struct{}
}
func (m *mockPeer) SendMessage(msg lnwire.Message) error {
func (m *mockPeer) SendMessage(msg lnwire.Message, sync bool) error {
select {
case m.sentMsgs <- msg:
case <-m.quit:

@ -447,7 +447,7 @@ func (s *mockServer) intersect(f messageInterceptor) {
s.interceptorFuncs = append(s.interceptorFuncs, f)
}
func (s *mockServer) SendMessage(message lnwire.Message) error {
func (s *mockServer) SendMessage(message lnwire.Message, sync bool) error {
select {
case s.messages <- message: