aboutsummaryrefslogtreecommitdiffstats
path: root/chain/helper_test.go
blob: 8c7532111a6cc0185631ac77fc2153f0f7a299aa (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
package chain

import (
    "container/list"
    "fmt"

    "github.com/ethereum/go-ethereum/chain/types"
    "github.com/ethereum/go-ethereum/crypto"
    "github.com/ethereum/go-ethereum/ethdb"
    "github.com/ethereum/go-ethereum/ethutil"
    "github.com/ethereum/go-ethereum/event"
    "github.com/ethereum/go-ethereum/wire"
)

// Implement our EthTest Manager
type TestManager struct {
    // stateManager *StateManager
    eventMux *event.TypeMux

    db         ethutil.Database
    txPool     *TxPool
    blockChain *ChainManager
    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
// }

func (tm *TestManager) EventMux() *event.TypeMux {
    return tm.eventMux
}
func (tm *TestManager) Broadcast(msgType wire.MsgType, data []interface{}) {
    fmt.Println("Broadcast not implemented")
}

func (tm *TestManager) ClientIdentity() wire.ClientIdentity {
    return nil
}
func (tm *TestManager) KeyManager() *crypto.KeyManager {
    return nil
}

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{}
    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
}