forked from mirror/go-ethereum
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
121 lines
2.7 KiB
121 lines
2.7 KiB
10 years ago
|
package blockpool
|
||
|
|
||
|
import (
|
||
|
"math/big"
|
||
|
"testing"
|
||
|
|
||
|
"github.com/ethereum/go-ethereum/blockpool/test"
|
||
|
)
|
||
|
|
||
|
// the actual tests
|
||
|
func TestAddPeer(t *testing.T) {
|
||
|
test.LogInit()
|
||
|
_, blockPool, blockPoolTester := newTestBlockPool(t)
|
||
|
peer0 := blockPoolTester.newPeer("peer0", 1, 0)
|
||
|
peer1 := blockPoolTester.newPeer("peer1", 2, 1)
|
||
|
peer2 := blockPoolTester.newPeer("peer2", 3, 2)
|
||
|
var bestpeer *peer
|
||
|
|
||
|
blockPool.Start()
|
||
|
|
||
|
// pool
|
||
|
best := peer0.AddPeer()
|
||
|
if !best {
|
||
|
t.Errorf("peer0 (TD=1) not accepted as best")
|
||
|
}
|
||
|
if blockPool.peers.best.id != "peer0" {
|
||
|
t.Errorf("peer0 (TD=1) not set as best")
|
||
|
}
|
||
|
|
||
|
best = peer2.AddPeer()
|
||
|
if !best {
|
||
|
t.Errorf("peer2 (TD=3) not accepted as best")
|
||
|
}
|
||
|
if blockPool.peers.best.id != "peer2" {
|
||
|
t.Errorf("peer2 (TD=3) not set as best")
|
||
|
}
|
||
|
peer2.waitBlocksRequests(2)
|
||
|
|
||
|
best = peer1.AddPeer()
|
||
|
if best {
|
||
|
t.Errorf("peer1 (TD=2) accepted as best")
|
||
|
}
|
||
|
if blockPool.peers.best.id != "peer2" {
|
||
|
t.Errorf("peer2 (TD=3) not set any more as best")
|
||
|
}
|
||
|
if blockPool.peers.best.td.Cmp(big.NewInt(int64(3))) != 0 {
|
||
|
t.Errorf("peer1 TD not set")
|
||
|
}
|
||
|
|
||
|
peer2.td = 4
|
||
|
peer2.currentBlock = 3
|
||
|
best = peer2.AddPeer()
|
||
|
if !best {
|
||
|
t.Errorf("peer2 (TD=4) not accepted as best")
|
||
|
}
|
||
|
if blockPool.peers.best.id != "peer2" {
|
||
|
t.Errorf("peer2 (TD=4) not set as best")
|
||
|
}
|
||
|
if blockPool.peers.best.td.Cmp(big.NewInt(int64(4))) != 0 {
|
||
|
t.Errorf("peer2 TD not updated")
|
||
|
}
|
||
|
peer2.waitBlocksRequests(3)
|
||
|
|
||
|
peer1.td = 3
|
||
|
peer1.currentBlock = 2
|
||
|
best = peer1.AddPeer()
|
||
|
if best {
|
||
|
t.Errorf("peer1 (TD=3) should not be set as best")
|
||
|
}
|
||
|
if blockPool.peers.best.id == "peer1" {
|
||
|
t.Errorf("peer1 (TD=3) should not be set as best")
|
||
|
}
|
||
|
bestpeer, best = blockPool.peers.getPeer("peer1")
|
||
|
if bestpeer.td.Cmp(big.NewInt(int64(3))) != 0 {
|
||
|
t.Errorf("peer1 TD should be updated")
|
||
|
}
|
||
|
|
||
|
blockPool.RemovePeer("peer2")
|
||
|
bestpeer, best = blockPool.peers.getPeer("peer2")
|
||
|
if bestpeer != nil {
|
||
|
t.Errorf("peer2 not removed")
|
||
|
}
|
||
|
|
||
|
if blockPool.peers.best.id != "peer1" {
|
||
|
t.Errorf("existing peer1 (TD=3) should be set as best peer")
|
||
|
}
|
||
|
peer1.waitBlocksRequests(2)
|
||
|
|
||
|
blockPool.RemovePeer("peer1")
|
||
|
bestpeer, best = blockPool.peers.getPeer("peer1")
|
||
|
if bestpeer != nil {
|
||
|
t.Errorf("peer1 not removed")
|
||
|
}
|
||
|
|
||
|
if blockPool.peers.best.id != "peer0" {
|
||
|
t.Errorf("existing peer0 (TD=1) should be set as best peer")
|
||
|
}
|
||
|
peer0.waitBlocksRequests(0)
|
||
|
|
||
|
blockPool.RemovePeer("peer0")
|
||
|
bestpeer, best = blockPool.peers.getPeer("peer0")
|
||
|
if bestpeer != nil {
|
||
|
t.Errorf("peer1 not removed")
|
||
|
}
|
||
|
|
||
|
// adding back earlier peer ok
|
||
|
peer0.currentBlock = 3
|
||
|
best = peer0.AddPeer()
|
||
|
if !best {
|
||
|
t.Errorf("peer0 (TD=1) should be set as best")
|
||
|
}
|
||
|
|
||
|
if blockPool.peers.best.id != "peer0" {
|
||
|
t.Errorf("peer0 (TD=1) should be set as best")
|
||
|
}
|
||
|
peer0.waitBlocksRequests(3)
|
||
|
|
||
|
blockPool.Stop()
|
||
|
|
||
|
}
|