From 382531435ee8516d01fdd3e5c7890d5fc90bebc1 Mon Sep 17 00:00:00 2001 From: Donald Adu-Poku Date: Thu, 21 Sep 2017 02:41:41 +0000 Subject: [PATCH] peer: fix logic race in peer connection test. --- peer/peer_test.go | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/peer/peer_test.go b/peer/peer_test.go index 4b2fb833c9..49cb655dbe 100644 --- a/peer/peer_test.go +++ b/peer/peer_test.go @@ -11,6 +11,7 @@ import ( "io" "net" "strconv" + "sync" "testing" "time" @@ -207,6 +208,7 @@ func testPeer(t *testing.T, p *peer.Peer, s peerStats) { // TestPeerConnection tests connection between inbound and outbound peers. func TestPeerConnection(t *testing.T) { + var pause sync.Mutex verack := make(chan struct{}) peerCfg := &peer.Config{ Listeners: peer.MessageListeners{ @@ -218,6 +220,8 @@ func TestPeerConnection(t *testing.T) { if _, ok := msg.(*wire.MsgVerAck); ok { verack <- struct{}{} } + pause.Lock() + pause.Unlock() }, }, UserAgentName: "peer", @@ -303,8 +307,11 @@ func TestPeerConnection(t *testing.T) { t.Errorf("TestPeerConnection setup #%d: unexpected err %v", i, err) return } + + pause.Lock() testPeer(t, inPeer, wantStats) testPeer(t, outPeer, wantStats) + pause.Unlock() inPeer.Disconnect() outPeer.Disconnect()