|
|
@@ -4,6 +4,7 @@ import (
|
|
|
"fmt"
|
|
|
"net"
|
|
|
"reflect"
|
|
|
+ "sync"
|
|
|
"testing"
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
|
@@ -36,50 +37,71 @@ func newTestPeer() (peer *Peer) {
|
|
|
}
|
|
|
|
|
|
func TestBaseProtocolPeers(t *testing.T) {
|
|
|
- cannedPeerList := []*peerAddr{
|
|
|
+ peerList := []*peerAddr{
|
|
|
{IP: net.ParseIP("1.2.3.4"), Port: 2222, Pubkey: []byte{}},
|
|
|
{IP: net.ParseIP("5.6.7.8"), Port: 3333, Pubkey: []byte{}},
|
|
|
}
|
|
|
- var ownAddr *peerAddr = &peerAddr{IP: net.ParseIP("1.3.5.7"), Port: 1111, Pubkey: []byte{}}
|
|
|
+ listenAddr := &peerAddr{IP: net.ParseIP("1.3.5.7"), Port: 1111, Pubkey: []byte{}}
|
|
|
rw1, rw2 := MsgPipe()
|
|
|
+ defer rw1.Close()
|
|
|
+ wg := new(sync.WaitGroup)
|
|
|
+
|
|
|
// run matcher, close pipe when addresses have arrived
|
|
|
- addrChan := make(chan *peerAddr, len(cannedPeerList))
|
|
|
+ numPeers := len(peerList) + 1
|
|
|
+ addrChan := make(chan *peerAddr)
|
|
|
+ wg.Add(1)
|
|
|
go func() {
|
|
|
- for _, want := range cannedPeerList {
|
|
|
- got := <-addrChan
|
|
|
- t.Logf("got peer: %+v", got)
|
|
|
+ i := 0
|
|
|
+ for got := range addrChan {
|
|
|
+ var want *peerAddr
|
|
|
+ switch {
|
|
|
+ case i < len(peerList):
|
|
|
+ want = peerList[i]
|
|
|
+ case i == len(peerList):
|
|
|
+ want = listenAddr // listenAddr should be the last thing sent
|
|
|
+ }
|
|
|
+ t.Logf("got peer %d/%d: %v", i+1, numPeers, got)
|
|
|
if !reflect.DeepEqual(want, got) {
|
|
|
- t.Errorf("mismatch: got %#v, want %#v", got, want)
|
|
|
+ t.Errorf("mismatch: got %+v, want %+v", got, want)
|
|
|
+ }
|
|
|
+ i++
|
|
|
+ if i == numPeers {
|
|
|
+ break
|
|
|
}
|
|
|
}
|
|
|
- close(addrChan)
|
|
|
- var own []*peerAddr
|
|
|
- var got *peerAddr
|
|
|
- for got = range addrChan {
|
|
|
- own = append(own, got)
|
|
|
- }
|
|
|
- if len(own) != 1 || !reflect.DeepEqual(ownAddr, own[0]) {
|
|
|
- t.Errorf("mismatch: peers own address is incorrectly or not given, got %v, want %#v", ownAddr)
|
|
|
+ if i != numPeers {
|
|
|
+ t.Errorf("wrong number of peers received: got %d, want %d", i, numPeers)
|
|
|
}
|
|
|
- rw2.Close()
|
|
|
+ rw1.Close()
|
|
|
+ wg.Done()
|
|
|
}()
|
|
|
- // run first peer
|
|
|
+
|
|
|
+ // run first peer (in background)
|
|
|
peer1 := newTestPeer()
|
|
|
- peer1.ourListenAddr = ownAddr
|
|
|
+ peer1.ourListenAddr = listenAddr
|
|
|
peer1.otherPeers = func() []*Peer {
|
|
|
- pl := make([]*Peer, len(cannedPeerList))
|
|
|
- for i, addr := range cannedPeerList {
|
|
|
+ pl := make([]*Peer, len(peerList))
|
|
|
+ for i, addr := range peerList {
|
|
|
pl[i] = &Peer{listenAddr: addr}
|
|
|
}
|
|
|
return pl
|
|
|
}
|
|
|
- go runBaseProtocol(peer1, rw1)
|
|
|
+ wg.Add(1)
|
|
|
+ go func() {
|
|
|
+ runBaseProtocol(peer1, rw1)
|
|
|
+ wg.Done()
|
|
|
+ }()
|
|
|
+
|
|
|
// run second peer
|
|
|
peer2 := newTestPeer()
|
|
|
peer2.newPeerAddr = addrChan // feed peer suggestions into matcher
|
|
|
if err := runBaseProtocol(peer2, rw2); err != ErrPipeClosed {
|
|
|
t.Errorf("peer2 terminated with unexpected error: %v", err)
|
|
|
}
|
|
|
+
|
|
|
+ // terminate matcher
|
|
|
+ close(addrChan)
|
|
|
+ wg.Wait()
|
|
|
}
|
|
|
|
|
|
func TestBaseProtocolDisconnect(t *testing.T) {
|
|
|
@@ -93,7 +115,7 @@ func TestBaseProtocolDisconnect(t *testing.T) {
|
|
|
if err := expectMsg(rw2, handshakeMsg); err != nil {
|
|
|
t.Error(err)
|
|
|
}
|
|
|
- err := rw2.EncodeMsg(handshakeMsg,
|
|
|
+ err := EncodeMsg(rw2, handshakeMsg,
|
|
|
baseProtocolVersion,
|
|
|
"",
|
|
|
[]interface{}{},
|
|
|
@@ -106,7 +128,7 @@ func TestBaseProtocolDisconnect(t *testing.T) {
|
|
|
if err := expectMsg(rw2, getPeersMsg); err != nil {
|
|
|
t.Error(err)
|
|
|
}
|
|
|
- if err := rw2.EncodeMsg(discMsg, DiscQuitting); err != nil {
|
|
|
+ if err := EncodeMsg(rw2, discMsg, DiscQuitting); err != nil {
|
|
|
t.Error(err)
|
|
|
}
|
|
|
|