From 7b476004cf3ef3bbae0351b9276780d0495a50a0 Mon Sep 17 00:00:00 2001 From: bap2pecs Date: Mon, 16 Dec 2024 21:48:19 +0800 Subject: [PATCH 1/2] fix --- finality-provider/service/fp_instance.go | 92 ++++++++++++------------ 1 file changed, 47 insertions(+), 45 deletions(-) diff --git a/finality-provider/service/fp_instance.go b/finality-provider/service/fp_instance.go index 211060d4..6ffe8c9e 100644 --- a/finality-provider/service/fp_instance.go +++ b/finality-provider/service/fp_instance.go @@ -340,58 +340,60 @@ func (fp *FinalityProviderInstance) retrySubmitSigsUntilFinalized(targetBlocks [ var failedCycles uint32 targetHeight := targetBlocks[len(targetBlocks)-1].Height - // we break the for loop if the block is finalized or the signature is successfully submitted - // error will be returned if maximum retries have been reached or the query to the consumer chain fails + // First iteration happens before the loop for { - select { - case <-time.After(fp.cfg.SubmissionRetryInterval): - // error will be returned if max retries have been reached - var res *types.TxResponse - var err error - res, err = fp.SubmitBatchFinalitySignatures(targetBlocks) - if err != nil { - fp.logger.Debug( - "failed to submit finality signature to the consumer chain", - zap.String("pk", fp.GetBtcPkHex()), - zap.Uint32("current_failures", failedCycles), - zap.Uint64("target_start_height", targetBlocks[0].Height), - zap.Uint64("target_end_height", targetHeight), - zap.Error(err), - ) - - if clientcontroller.IsUnrecoverable(err) { - return nil, err - } - - if clientcontroller.IsExpected(err) { - return nil, nil - } + // Attempt submission immediately + // error will be returned if max retries have been reached + var res *types.TxResponse + var err error + res, err = fp.SubmitBatchFinalitySignatures(targetBlocks) + if err != nil { + fp.logger.Debug( + "failed to submit finality signature to the consumer chain", + zap.String("pk", fp.GetBtcPkHex()), + zap.Uint32("current_failures", failedCycles), + zap.Uint64("target_start_height", targetBlocks[0].Height), + zap.Uint64("target_end_height", targetHeight), + zap.Error(err), + ) - failedCycles++ - if failedCycles > fp.cfg.MaxSubmissionRetries { - return nil, fmt.Errorf("reached max failed cycles with err: %w", err) - } - } else { - // the signature has been successfully submitted - return res, nil + if clientcontroller.IsUnrecoverable(err) { + return nil, err } - // periodically query the index block to be later checked whether it is Finalized - finalized, err := fp.checkBlockFinalization(targetHeight) - if err != nil { - return nil, fmt.Errorf("failed to query block finalization at height %v: %w", targetHeight, err) - } - if finalized { - fp.logger.Debug( - "the block is already finalized, skip submission", - zap.String("pk", fp.GetBtcPkHex()), - zap.Uint64("target_height", targetHeight), - ) - // TODO: returning nil here is to safely break the loop - // the error still exists + if clientcontroller.IsExpected(err) { return nil, nil } + failedCycles++ + if failedCycles > fp.cfg.MaxSubmissionRetries { + return nil, fmt.Errorf("reached max failed cycles with err: %w", err) + } + } else { + // the signature has been successfully submitted + return res, nil + } + + // periodically query the index block to be later checked whether it is Finalized + finalized, err := fp.checkBlockFinalization(targetHeight) + if err != nil { + return nil, fmt.Errorf("failed to query block finalization at height %v: %w", targetHeight, err) + } + if finalized { + fp.logger.Debug( + "the block is already finalized, skip submission", + zap.String("pk", fp.GetBtcPkHex()), + zap.Uint64("target_height", targetHeight), + ) + // TODO: returning nil here is to safely break the loop + // the error still exists + return nil, nil + } + + // Wait for the retry interval + select { + case <-time.After(fp.cfg.SubmissionRetryInterval): + // Continue to next retry iteration case <-fp.quit: fp.logger.Debug("the finality-provider instance is closing", zap.String("pk", fp.GetBtcPkHex())) return nil, ErrFinalityProviderShutDown From d58fab543784f2c006e54d755ebf3f679d074db2 Mon Sep 17 00:00:00 2001 From: bap2pecs Date: Mon, 16 Dec 2024 21:50:18 +0800 Subject: [PATCH 2/2] doc --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 735cdaea..8d505030 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -45,6 +45,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) * [#214](https://github.com/babylonlabs-io/finality-provider/pull/214) Gradual benchmark * [#216](https://github.com/babylonlabs-io/finality-provider/pull/216) Add multiple fpd connecting to one eotsd in e2e tests * [#218](https://github.com/babylonlabs-io/finality-provider/pull/218) Prune used merkle proof +* [#227](https://github.com/babylonlabs-io/finality-provider/pull/227) Fix FP submission loop ## v0.13.1