aboutsummaryrefslogtreecommitdiffstats
path: root/blockpool/errors_test.go
diff options
context:
space:
mode:
authorobscuren <geffobscura@gmail.com>2015-04-09 23:40:28 +0800
committerobscuren <geffobscura@gmail.com>2015-04-09 23:40:28 +0800
commit01ee01219713c80fc9064e9840b42ff2fce374d7 (patch)
tree02daa2105b89b5b6419521785f6f54d217ed544c /blockpool/errors_test.go
parent0636e17dbee3accf6291000f0e4f4e713a97a207 (diff)
parent764a802eaa33892447b82069ee1b1bb5a478837b (diff)
downloadgo-tangerine-01ee01219713c80fc9064e9840b42ff2fce374d7.tar
go-tangerine-01ee01219713c80fc9064e9840b42ff2fce374d7.tar.gz
go-tangerine-01ee01219713c80fc9064e9840b42ff2fce374d7.tar.bz2
go-tangerine-01ee01219713c80fc9064e9840b42ff2fce374d7.tar.lz
go-tangerine-01ee01219713c80fc9064e9840b42ff2fce374d7.tar.xz
go-tangerine-01ee01219713c80fc9064e9840b42ff2fce374d7.tar.zst
go-tangerine-01ee01219713c80fc9064e9840b42ff2fce374d7.zip
Merge branch 'ethersphere-frontier/blockpool' into develop
Diffstat (limited to 'blockpool/errors_test.go')
-rw-r--r--blockpool/errors_test.go45
1 files changed, 43 insertions, 2 deletions
diff --git a/blockpool/errors_test.go b/blockpool/errors_test.go
index c56b3d304..b0b831270 100644
--- a/blockpool/errors_test.go
+++ b/blockpool/errors_test.go
@@ -39,6 +39,8 @@ func TestInvalidBlock(t *testing.T) {
}
func TestVerifyPoW(t *testing.T) {
+ t.Skip() // :FIXME:
+
test.LogInit()
_, blockPool, blockPoolTester := newTestBlockPool(t)
blockPoolTester.blockChain[0] = nil
@@ -84,6 +86,8 @@ func TestVerifyPoW(t *testing.T) {
}
func TestUnrequestedBlock(t *testing.T) {
+ t.Skip() // :FIXME:
+
test.LogInit()
_, blockPool, blockPoolTester := newTestBlockPool(t)
blockPoolTester.blockChain[0] = nil
@@ -124,8 +128,6 @@ func TestErrInsufficientChainInfo(t *testing.T) {
}
func TestIncorrectTD(t *testing.T) {
- t.Skip() // @zelig this one requires fixing for the TD
-
test.LogInit()
_, blockPool, blockPoolTester := newTestBlockPool(t)
blockPoolTester.blockChain[0] = nil
@@ -152,6 +154,45 @@ func TestIncorrectTD(t *testing.T) {
}
}
+func TestSkipIncorrectTDonFutureBlocks(t *testing.T) {
+ // t.Skip() // @zelig this one requires fixing for the TD
+
+ test.LogInit()
+ _, blockPool, blockPoolTester := newTestBlockPool(t)
+ blockPoolTester.blockChain[0] = nil
+ blockPoolTester.initRefBlockChain(3)
+
+ blockPool.insertChain = func(blocks types.Blocks) error {
+ err := blockPoolTester.insertChain(blocks)
+ if err == nil {
+ for _, block := range blocks {
+ if block.Td.Cmp(common.Big3) == 0 {
+ block.Td = common.Big3
+ block.SetQueued(true)
+ break
+ }
+ }
+ }
+ return err
+ }
+
+ blockPool.Start()
+
+ peer1 := blockPoolTester.newPeer("peer1", 3, 3)
+ peer1.AddPeer()
+ go peer1.serveBlocks(2, 3)
+ go peer1.serveBlockHashes(3, 2, 1, 0)
+ peer1.serveBlocks(0, 1, 2)
+
+ blockPool.Wait(waitTimeout)
+ blockPool.Stop()
+ blockPoolTester.refBlockChain[3] = []int{}
+ blockPoolTester.checkBlockChain(blockPoolTester.refBlockChain)
+ if len(peer1.peerErrors) > 0 {
+ t.Errorf("expected no error, got %v (1 of %v)", peer1.peerErrors[0], len(peer1.peerErrors))
+ }
+}
+
func TestPeerSuspension(t *testing.T) {
test.LogInit()
_, blockPool, blockPoolTester := newTestBlockPool(t)