From cff2cccac8ee2b0a72f1879e5f58514a6f36012f Mon Sep 17 00:00:00 2001 From: Alexander Sporn Date: Tue, 7 May 2024 09:06:01 +0200 Subject: [PATCH] Do not rollback pool stats and upgrade signals on the last slot of an epoch --- pkg/storage/prunable/prunable.go | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/pkg/storage/prunable/prunable.go b/pkg/storage/prunable/prunable.go index c7590a651..b09590913 100644 --- a/pkg/storage/prunable/prunable.go +++ b/pkg/storage/prunable/prunable.go @@ -184,19 +184,22 @@ func (p *Prunable) Rollback(targetEpoch iotago.EpochIndex, startPruneRange iotag return ierrors.Wrapf(err, "failed to rollback committee epochs to target epoch %d", targetEpoch) } - lastPrunedPoolStatsEpoch, _, err := p.poolStats.RollbackEpochs(targetEpoch) - if err != nil { - return ierrors.Wrapf(err, "failed to rollback pool stats epochs to target epoch %d", targetEpoch) - } - - lastPrunedDecidedUpgradeSignalsEpoch, _, err := p.decidedUpgradeSignals.RollbackEpochs(targetEpoch) - if err != nil { - return ierrors.Wrapf(err, "failed to rollback decided upgrade signals epochs to target epoch %d", targetEpoch) - } - + var lastPrunedPoolStatsEpoch iotago.EpochIndex + var lastPrunedDecidedUpgradeSignalsEpoch iotago.EpochIndex var lastPrunedPoolRewardsEpoch iotago.EpochIndex // Do not rollback the epoch if the targetSlot is the end of the epoch, because that is when we calculated the rewards. if targetSlot := startPruneRange - 1; p.apiProvider.APIForSlot(targetSlot).TimeProvider().EpochEnd(targetEpoch) != targetSlot { + + lastPrunedPoolStatsEpoch, _, err = p.poolStats.RollbackEpochs(targetEpoch) + if err != nil { + return ierrors.Wrapf(err, "failed to rollback pool stats epochs to target epoch %d", targetEpoch) + } + + lastPrunedDecidedUpgradeSignalsEpoch, _, err = p.decidedUpgradeSignals.RollbackEpochs(targetEpoch) + if err != nil { + return ierrors.Wrapf(err, "failed to rollback decided upgrade signals epochs to target epoch %d", targetEpoch) + } + lastPrunedPoolRewardsEpoch, err = p.poolRewards.RollbackEpochs(targetEpoch) if err != nil { return ierrors.Wrapf(err, "failed to rollback pool rewards epochs to target epoch %d", targetEpoch)