Fixed chain test & added new chain

This commit is contained in:
obscuren 2014-12-30 13:32:01 +01:00
parent ce68ac6959
commit 2f8a45cd8b
5 changed files with 37 additions and 17 deletions

Binary file not shown.

Binary file not shown.

View File

@ -2,7 +2,9 @@ package core
import ( import (
"fmt" "fmt"
"os"
"path" "path"
"reflect"
"runtime" "runtime"
"testing" "testing"
@ -10,6 +12,7 @@ import (
"github.com/ethereum/go-ethereum/ethdb" "github.com/ethereum/go-ethereum/ethdb"
"github.com/ethereum/go-ethereum/ethutil" "github.com/ethereum/go-ethereum/ethutil"
"github.com/ethereum/go-ethereum/event" "github.com/ethereum/go-ethereum/event"
"github.com/ethereum/go-ethereum/rlp"
//logpkg "github.com/ethereum/go-ethereum/logger" //logpkg "github.com/ethereum/go-ethereum/logger"
) )
@ -30,20 +33,19 @@ func init() {
ethutil.Config.Db = db ethutil.Config.Db = db
} }
func loadChain(fn string, t *testing.T) types.Blocks { func loadChain(fn string, t *testing.T) (types.Blocks, error) {
c1, err := ethutil.ReadAllFile(path.Join("..", "_data", fn)) fh, err := os.OpenFile(path.Join("..", "_data", fn), os.O_RDONLY, os.ModePerm)
if err != nil { if err != nil {
fmt.Println(err) return nil, err
t.FailNow()
} }
value := ethutil.NewValueFromBytes([]byte(c1)) defer fh.Close()
blocks := make(types.Blocks, value.Len())
it := value.NewIterator() var chain types.Blocks
for it.Next() { if err := rlp.Decode(fh, &chain); err != nil {
blocks[it.Idx()] = types.NewBlockFromRlpValue(it.Value()) return nil, err
} }
return blocks return chain, nil
} }
func insertChain(done chan bool, chainMan *ChainManager, chain types.Blocks, t *testing.T) { func insertChain(done chan bool, chainMan *ChainManager, chain types.Blocks, t *testing.T) {
@ -56,11 +58,21 @@ func insertChain(done chan bool, chainMan *ChainManager, chain types.Blocks, t *
} }
func TestChainInsertions(t *testing.T) { func TestChainInsertions(t *testing.T) {
chain1 := loadChain("chain1", t) chain1, err := loadChain("chain1", t)
chain2 := loadChain("chain2", t) if err != nil {
fmt.Println(err)
t.FailNow()
}
chain2, err := loadChain("chain2", t)
if err != nil {
fmt.Println(err)
t.FailNow()
}
var eventMux event.TypeMux var eventMux event.TypeMux
chainMan := NewChainManager(&eventMux) chainMan := NewChainManager(&eventMux)
txPool := NewTxPool(chainMan, nil, &eventMux) txPool := NewTxPool(chainMan, &eventMux)
blockMan := NewBlockManager(txPool, chainMan, &eventMux) blockMan := NewBlockManager(txPool, chainMan, &eventMux)
chainMan.SetProcessor(blockMan) chainMan.SetProcessor(blockMan)
@ -73,5 +85,12 @@ func TestChainInsertions(t *testing.T) {
for i := 0; i < max; i++ { for i := 0; i < max; i++ {
<-done <-done
} }
fmt.Println(chainMan.CurrentBlock())
if reflect.DeepEqual(chain2[len(chain2)-1], chainMan.CurrentBlock()) {
t.Error("chain2 is canonical and shouldn't be")
}
if !reflect.DeepEqual(chain1[len(chain1)-1], chainMan.CurrentBlock()) {
t.Error("chain1 isn't canonical and should be")
}
} }

View File

@ -9,7 +9,7 @@ import (
"github.com/ethereum/go-ethereum/ethdb" "github.com/ethereum/go-ethereum/ethdb"
"github.com/ethereum/go-ethereum/ethutil" "github.com/ethereum/go-ethereum/ethutil"
"github.com/ethereum/go-ethereum/event" "github.com/ethereum/go-ethereum/event"
"github.com/ethereum/go-ethereum/wire" "github.com/ethereum/go-ethereum/p2p"
) )
// Implement our EthTest Manager // Implement our EthTest Manager
@ -54,11 +54,11 @@ func (tm *TestManager) TxPool() *TxPool {
func (tm *TestManager) EventMux() *event.TypeMux { func (tm *TestManager) EventMux() *event.TypeMux {
return tm.eventMux return tm.eventMux
} }
func (tm *TestManager) Broadcast(msgType wire.MsgType, data []interface{}) { func (tm *TestManager) Broadcast(msgType p2p.Msg, data []interface{}) {
fmt.Println("Broadcast not implemented") fmt.Println("Broadcast not implemented")
} }
func (tm *TestManager) ClientIdentity() wire.ClientIdentity { func (tm *TestManager) ClientIdentity() p2p.ClientIdentity {
return nil return nil
} }
func (tm *TestManager) KeyManager() *crypto.KeyManager { func (tm *TestManager) KeyManager() *crypto.KeyManager {

View File

@ -199,6 +199,7 @@ func (self *Block) Hash() []byte { return self.header.Hash() }
func (self *Block) Trie() *ptrie.Trie { return ptrie.New(self.header.Root, ethutil.Config.Db) } func (self *Block) Trie() *ptrie.Trie { return ptrie.New(self.header.Root, ethutil.Config.Db) }
func (self *Block) State() *state.StateDB { return state.New(self.Trie()) } func (self *Block) State() *state.StateDB { return state.New(self.Trie()) }
func (self *Block) Size() ethutil.StorageSize { return ethutil.StorageSize(len(ethutil.Encode(self))) } func (self *Block) Size() ethutil.StorageSize { return ethutil.StorageSize(len(ethutil.Encode(self))) }
func (self *Block) SetRoot(root []byte) { self.header.Root = root }
// Implement block.Pow // Implement block.Pow
func (self *Block) Difficulty() *big.Int { return self.header.Difficulty } func (self *Block) Difficulty() *big.Int { return self.header.Difficulty }