From ffd0b6cc9dd3f01220db0ca70cbc71c9bbd4ec0d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Stefan=20Negovanovi=C4=87?= Date: Wed, 24 Apr 2024 10:21:02 +0200 Subject: [PATCH] Add error to the StartRound signature --- core/backend.go | 2 +- core/ibft.go | 6 +++++- core/mock_test.go | 8 +++++--- 3 files changed, 11 insertions(+), 5 deletions(-) diff --git a/core/backend.go b/core/backend.go index 8a95f3d..3b86088 100644 --- a/core/backend.go +++ b/core/backend.go @@ -63,7 +63,7 @@ type Backend interface { ValidatorBackend // StartRound notifies the backend implementation whenever new round is about to start - StartRound(view *proto.View) + StartRound(view *proto.View) error // BuildProposal builds a new proposal for the given view (height and round) BuildProposal(view *proto.View) []byte diff --git a/core/ibft.go b/core/ibft.go index 4608087..809b710 100644 --- a/core/ibft.go +++ b/core/ibft.go @@ -323,7 +323,11 @@ func (i *IBFT) RunSequence(ctx context.Context, h uint64) { for { view := i.state.getView() - i.backend.StartRound(view) + if err := i.backend.StartRound(view); err != nil { + i.log.Error("failed to start round on backend, aborting sequence...", "round", view.Round, "err", err) + + return + } i.log.Info("round started", "round", view.Round) diff --git a/core/mock_test.go b/core/mock_test.go index 342f84e..90adef7 100644 --- a/core/mock_test.go +++ b/core/mock_test.go @@ -64,7 +64,7 @@ type buildRoundChangeMessageDelegate func( type insertProposalDelegate func(*proto.Proposal, []*messages.CommittedSeal) type idDelegate func() []byte type getVotingPowerDelegate func(uint64) (map[string]*big.Int, error) -type startRoundDelegate func(*proto.View) +type startRoundDelegate func(*proto.View) error var _ Backend = &mockBackend{} @@ -204,10 +204,12 @@ func (m mockBackend) GetVotingPowers(height uint64) (map[string]*big.Int, error) return map[string]*big.Int{}, nil } -func (m mockBackend) StartRound(view *proto.View) { +func (m mockBackend) StartRound(view *proto.View) error { if m.startRoundFn != nil { - m.startRoundFn(view) + return m.startRoundFn(view) } + + return nil } // Define delegation methods