aboutsummaryrefslogtreecommitdiffstats
path: root/simulation/validator.go
diff options
context:
space:
mode:
authorJimmy Hu <jimmy.hu@dexon.org>2018-08-31 13:34:00 +0800
committerGitHub <noreply@github.com>2018-08-31 13:34:00 +0800
commit18c6a28ff021c9dc643091b5dc420b51183253cf (patch)
tree3017ffcfc03532289b1856f5f9a1a83012eb5d8e /simulation/validator.go
parent123a7ee3bcf96c5bbef2ea16737d1a8e25f5ef30 (diff)
downloaddexon-consensus-18c6a28ff021c9dc643091b5dc420b51183253cf.tar
dexon-consensus-18c6a28ff021c9dc643091b5dc420b51183253cf.tar.gz
dexon-consensus-18c6a28ff021c9dc643091b5dc420b51183253cf.tar.bz2
dexon-consensus-18c6a28ff021c9dc643091b5dc420b51183253cf.tar.lz
dexon-consensus-18c6a28ff021c9dc643091b5dc420b51183253cf.tar.xz
dexon-consensus-18c6a28ff021c9dc643091b5dc420b51183253cf.tar.zst
dexon-consensus-18c6a28ff021c9dc643091b5dc420b51183253cf.zip
Add methods to Application interface. (#86)
Diffstat (limited to 'simulation/validator.go')
-rw-r--r--simulation/validator.go94
1 files changed, 4 insertions, 90 deletions
diff --git a/simulation/validator.go b/simulation/validator.go
index a54c848..6d73c50 100644
--- a/simulation/validator.go
+++ b/simulation/validator.go
@@ -105,26 +105,15 @@ func (v *Validator) Run() {
time.Duration(v.config.ProposeIntervalMean)*time.Millisecond),
v.prvKey, v.sigToPub)
- genesisBlock := &types.Block{
- ProposerID: v.ID,
- ChainID: v.chainID,
- }
- err := v.consensus.PrepareGenesisBlock(genesisBlock, time.Now().UTC())
- if err != nil {
- panic(err)
- }
- isStopped := make(chan struct{}, 2)
+ go v.consensus.Run()
+
isShutdown := make(chan struct{})
- v.app.addBlock(genesisBlock)
- v.consensus.ProcessBlock(genesisBlock)
- v.BroadcastGenesisBlock(genesisBlock)
- go v.MsgServer(isStopped)
go v.CheckServerInfo(isShutdown)
- go v.BlockProposer(isStopped, isShutdown)
// Blocks forever.
- <-isStopped
+ <-isShutdown
+ v.consensus.Stop()
if err := v.db.Close(); err != nil {
fmt.Println(err)
}
@@ -151,78 +140,3 @@ func (v *Validator) CheckServerInfo(isShutdown chan struct{}) {
time.Sleep(250 * time.Millisecond)
}
}
-
-// MsgServer listen to the network channel for message and handle it.
-func (v *Validator) MsgServer(
- isStopped chan struct{}) {
-
- for {
- var msg interface{}
- select {
- case msg = <-v.msgChannel:
- case <-isStopped:
- return
- }
-
- switch val := msg.(type) {
- case *types.Block:
- v.app.addBlock(val)
- if err := v.consensus.ProcessBlock(val); err != nil {
- fmt.Println(err)
- }
- types.RecycleBlock(val)
- case *types.NotaryAck:
- if err := v.consensus.ProcessNotaryAck(val); err != nil {
- fmt.Println(err)
- }
- case *types.Vote:
- if err := v.consensus.ProcessVote(val); err != nil {
- fmt.Println(err)
- }
- }
- }
-}
-
-// BroadcastGenesisBlock broadcasts genesis block to all peers.
-func (v *Validator) BroadcastGenesisBlock(genesisBlock *types.Block) {
- // Wait until all peer joined the network.
- for v.network.NumPeers() != v.config.Num {
- time.Sleep(time.Second)
- }
- v.network.BroadcastBlock(genesisBlock)
-}
-
-// BlockProposer propose blocks to be send to the DEXON network.
-func (v *Validator) BlockProposer(isStopped, isShutdown chan struct{}) {
- model := &NormalNetwork{
- Sigma: v.config.ProposeIntervalSigma,
- Mean: v.config.ProposeIntervalMean,
- }
-ProposingBlockLoop:
- for {
- time.Sleep(model.Delay())
-
- block := &types.Block{
- ProposerID: v.ID,
- ChainID: v.chainID,
- Hash: common.NewRandomHash(),
- }
- if err := v.consensus.PrepareBlock(block, time.Now().UTC()); err != nil {
- panic(err)
- }
- v.app.addBlock(block)
- if err := v.consensus.ProcessBlock(block); err != nil {
- fmt.Println(err)
- //panic(err)
- }
- v.network.BroadcastBlock(block)
- select {
- case <-isShutdown:
- isStopped <- struct{}{}
- isStopped <- struct{}{}
- break ProposingBlockLoop
- default:
- break
- }
- }
-}