From 43bfc909ebd5577e8b5b1fd5baad02514c5b2bbd Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Thu, 4 Feb 2021 18:54:01 +0300 Subject: [PATCH] consensus: flush previous proposal on new block Reusing proposals from previous blocks doesn't make sense. And reduce some code duplication along the way. --- pkg/consensus/consensus.go | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/pkg/consensus/consensus.go b/pkg/consensus/consensus.go index 12d8be085..2eeaac4cc 100644 --- a/pkg/consensus/consensus.go +++ b/pkg/consensus/consensus.go @@ -320,9 +320,7 @@ func (s *service) handleChainBlock(b *coreb.Block) { s.log.Debug("new block in the chain", zap.Uint32("dbft index", s.dbft.BlockIndex), zap.Uint32("chain index", s.Chain.BlockHeight())) - if s.lastTimestamp < b.Timestamp { - s.lastTimestamp = b.Timestamp - } + s.postBlock(b) s.dbft.InitializeConsensus(0) } } @@ -527,9 +525,14 @@ func (s *service) processBlock(b block.Block) { s.log.Warn("error on add block", zap.Error(err)) } } - if s.lastTimestamp < bb.Timestamp { - s.lastTimestamp = bb.Timestamp + s.postBlock(bb) +} + +func (s *service) postBlock(b *coreb.Block) { + if s.lastTimestamp < b.Timestamp { + s.lastTimestamp = b.Timestamp } + s.lastProposal = nil } func (s *service) getBlockWitness(b *coreb.Block) *transaction.Witness {