go-ethereum/core/helper_test.go

94 lines
1.9 KiB
Go
Raw Normal View History

2014-12-04 11:28:02 +02:00
package core
import (
"container/list"
"fmt"
"github.com/ethereum/go-ethereum/core/types"
2014-10-31 19:40:32 +02:00
"github.com/ethereum/go-ethereum/crypto"
"github.com/ethereum/go-ethereum/ethdb"
"github.com/ethereum/go-ethereum/ethutil"
"github.com/ethereum/go-ethereum/event"
2014-12-30 14:32:01 +02:00
"github.com/ethereum/go-ethereum/p2p"
)
// Implement our EthTest Manager
type TestManager struct {
// stateManager *StateManager
eventMux *event.TypeMux
2014-10-14 03:01:46 +03:00
db ethutil.Database
txPool *TxPool
blockChain *ChainManager
2014-11-18 20:52:45 +02:00
Blocks []*types.Block
}
func (s *TestManager) IsListening() bool {
return false
}
func (s *TestManager) IsMining() bool {
return false
}
func (s *TestManager) PeerCount() int {
return 0
}
func (s *TestManager) Peers() *list.List {
return list.New()
}
func (s *TestManager) ChainManager() *ChainManager {
return s.blockChain
}
func (tm *TestManager) TxPool() *TxPool {
return tm.txPool
}
// func (tm *TestManager) StateManager() *StateManager {
// return tm.stateManager
// }
2014-10-14 03:01:46 +03:00
func (tm *TestManager) EventMux() *event.TypeMux {
return tm.eventMux
}
2014-12-30 14:32:01 +02:00
func (tm *TestManager) Broadcast(msgType p2p.Msg, data []interface{}) {
fmt.Println("Broadcast not implemented")
}
2014-12-30 14:32:01 +02:00
func (tm *TestManager) ClientIdentity() p2p.ClientIdentity {
return nil
}
2014-10-31 19:40:32 +02:00
func (tm *TestManager) KeyManager() *crypto.KeyManager {
return nil
}
2014-10-14 03:01:46 +03:00
func (tm *TestManager) Db() ethutil.Database {
return tm.db
}
func NewTestManager() *TestManager {
ethutil.ReadConfig(".ethtest", "/tmp/ethtest", "ETH")
db, err := ethdb.NewMemDatabase()
if err != nil {
fmt.Println("Could not create mem-db, failing")
return nil
}
ethutil.Config.Db = db
testManager := &TestManager{}
2014-10-14 03:01:46 +03:00
testManager.eventMux = new(event.TypeMux)
testManager.db = db
// testManager.txPool = NewTxPool(testManager)
// testManager.blockChain = NewChainManager(testManager)
// testManager.stateManager = NewStateManager(testManager)
// Start the tx pool
testManager.txPool.Start()
return testManager
}