From 7223eb4ff673cae0fd1cdd5c37b5223fe9136a17 Mon Sep 17 00:00:00 2001 From: Kenny P <17100641+kpeluso@users.noreply.github.com> Date: Thu, 19 Sep 2024 00:45:56 -0400 Subject: [PATCH] ensure every score blockheight is built with nonce not current height (#610) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ## Purpose of Changes and their Description Scores were inconsistently using current height or nonce. I modified to just use nonces. I used this to also modify how we were checking for idempotent submissions (1 submission per actor type per topic per epoch). This is a simpler solution than https://github.com/allora-network/allora-chain/pull/609 ## Link(s) to Ticket(s) or Issue(s) resolved by this PR [From conversation](https://github.com/allora-network/allora-chain/pull/609) with @xmariachi and @guilherme-brandao ## Are these changes tested and documented? - [ ] If tested, please describe how. If not, why tests are not needed. - [ ] If documented, please describe where. If not, describe why docs are not needed. - [ ] Added to `Unreleased` section of `CHANGELOG.md`? ## Still Left Todo *Fill this out if this is a Draft PR so others can help.* --- CHANGELOG.md | 1 + x/emissions/keeper/keeper.go | 24 +++++++------------ x/emissions/keeper/keeper_test.go | 19 +++++++-------- .../msgserver/msg_server_reputer_payload.go | 2 +- .../msgserver/msg_server_worker_payload.go | 4 ++-- 5 files changed, 21 insertions(+), 29 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c65b5ffca..12de5ed84 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -73,6 +73,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Security * [#588](https://github.com/allora-network/allora-chain/pull/588) Add String Max Length Module Parameter, Enforce Max String Length on Creation of New Topics +* [#610](https://github.com/allora-network/allora-chain/pull/610) Ensure that BlockHeight of scores is consistently set to be a topic epoch nonce. Also simplify the condition for idempotent payload submission. ## v0.4.0 diff --git a/x/emissions/keeper/keeper.go b/x/emissions/keeper/keeper.go index 05e806fc3..ec3445367 100644 --- a/x/emissions/keeper/keeper.go +++ b/x/emissions/keeper/keeper.go @@ -796,7 +796,6 @@ func (k *Keeper) GetForecastsAtBlock(ctx context.Context, topicId TopicId, block func (k *Keeper) AppendInference( ctx sdk.Context, topic types.Topic, - blockHeight BlockHeight, nonceBlockHeight BlockHeight, inference *types.Inference, ) error { @@ -825,8 +824,7 @@ func (k *Keeper) AppendInference( return errorsmod.Wrapf(err, "Error getting inferer score ema") } // Only calc and save if there's a new update - if previousEmaScore.BlockHeight != 0 && - blockHeight-previousEmaScore.BlockHeight <= topic.WorkerSubmissionWindow { + if previousEmaScore.BlockHeight >= nonceBlockHeight { return types.ErrCantUpdateEmaMoreThanOncePerWindow } @@ -848,7 +846,7 @@ func (k *Keeper) AppendInference( err = k.CalcAndSaveInfererScoreEmaWithLastSavedTopicQuantile( ctx, topic, - blockHeight, + nonceBlockHeight, inferences.Inferences[lowScoreIndex].Inferer, ) if err != nil { @@ -861,7 +859,7 @@ func (k *Keeper) AppendInference( return k.InsertInferences(ctx, topic.Id, nonceBlockHeight, inferences) } else { // Update EMA score for the current inferer, who is the lowest score inferer - err = k.CalcAndSaveInfererScoreEmaWithLastSavedTopicQuantile(ctx, topic, blockHeight, inference.Inferer) + err = k.CalcAndSaveInfererScoreEmaWithLastSavedTopicQuantile(ctx, topic, nonceBlockHeight, inference.Inferer) if err != nil { return err } @@ -891,7 +889,6 @@ func (k *Keeper) InsertInferences( func (k *Keeper) AppendForecast( ctx sdk.Context, topic types.Topic, - blockHeight BlockHeight, nonceBlockHeight BlockHeight, forecast *types.Forecast, ) error { @@ -923,8 +920,7 @@ func (k *Keeper) AppendForecast( return errorsmod.Wrapf(err, "Error getting forecaster score ema") } // Only calc and save if there's a new update - if previousEmaScore.BlockHeight != 0 && - blockHeight-previousEmaScore.BlockHeight <= topic.WorkerSubmissionWindow { + if previousEmaScore.BlockHeight >= nonceBlockHeight { return types.ErrCantUpdateEmaMoreThanOncePerWindow } @@ -946,7 +942,7 @@ func (k *Keeper) AppendForecast( err = k.CalcAndSaveForecasterScoreEmaWithLastSavedTopicQuantile( ctx, topic, - blockHeight, + nonceBlockHeight, forecasts.Forecasts[lowScoreIndex].Forecaster, ) if err != nil { @@ -959,7 +955,7 @@ func (k *Keeper) AppendForecast( return k.InsertForecasts(ctx, topic.Id, nonceBlockHeight, forecasts) } else { // Update EMA score for the current forecaster, who is the lowest score forecaster - err = k.CalcAndSaveForecasterScoreEmaWithLastSavedTopicQuantile(ctx, topic, blockHeight, forecast.Forecaster) + err = k.CalcAndSaveForecasterScoreEmaWithLastSavedTopicQuantile(ctx, topic, nonceBlockHeight, forecast.Forecaster) if err != nil { return err } @@ -1019,7 +1015,6 @@ func (k *Keeper) DeleteTopicRewardNonce(ctx context.Context, topicId TopicId) er func (k *Keeper) AppendReputerLoss( ctx sdk.Context, topic types.Topic, - blockHeight BlockHeight, nonceBlockHeight BlockHeight, reputerLoss *types.ReputerValueBundle, ) error { @@ -1054,8 +1049,7 @@ func (k *Keeper) AppendReputerLoss( return err } // Only calc and save if there's a new update - if previousEmaScore.BlockHeight != 0 && - blockHeight-previousEmaScore.BlockHeight <= topic.EpochLength { + if previousEmaScore.BlockHeight >= nonceBlockHeight { return types.ErrCantUpdateEmaMoreThanOncePerWindow } @@ -1077,7 +1071,7 @@ func (k *Keeper) AppendReputerLoss( err = k.CalcAndSaveReputerScoreEmaWithLastSavedTopicQuantile( ctx, topic, - blockHeight, + nonceBlockHeight, reputerLossBundles.ReputerValueBundles[lowScoreIndex].ValueBundle.Reputer, ) if err != nil { @@ -1091,7 +1085,7 @@ func (k *Keeper) AppendReputerLoss( return k.InsertReputerLossBundlesAtBlock(ctx, topic.Id, nonceBlockHeight, reputerLossBundles) } else { // Update EMA score for the current reputer, who is the lowest score reputer - err = k.CalcAndSaveReputerScoreEmaWithLastSavedTopicQuantile(ctx, topic, blockHeight, reputerLoss.ValueBundle.Reputer) + err = k.CalcAndSaveReputerScoreEmaWithLastSavedTopicQuantile(ctx, topic, nonceBlockHeight, reputerLoss.ValueBundle.Reputer) if err != nil { return err } diff --git a/x/emissions/keeper/keeper_test.go b/x/emissions/keeper/keeper_test.go index f27b910b2..bf2635841 100644 --- a/x/emissions/keeper/keeper_test.go +++ b/x/emissions/keeper/keeper_test.go @@ -3497,7 +3497,7 @@ func (s *KeeperTestSuite) TestAppendInference() { newInference := types.Inference{ TopicId: topicId, BlockHeight: blockHeightInferences, Inferer: worker4, Value: alloraMath.MustNewDecFromString("0.52"), } - err = k.AppendInference(ctx, topic, blockHeightInferences, nonce.BlockHeight, &newInference) + err = k.AppendInference(ctx, topic, nonce.BlockHeight, &newInference) s.Require().NoError(err) newAllInferences, err := k.GetInferencesAtBlock(ctx, topicId, nonce.BlockHeight) s.Require().NoError(err) @@ -3516,7 +3516,7 @@ func (s *KeeperTestSuite) TestAppendInference() { } worker5OgScore, err := k.GetInfererScoreEma(ctx, topicId, worker5) s.Require().NoError(err) - err = k.AppendInference(ctx, topic, blockHeightInferences, nonce.BlockHeight, &newInference2) + err = k.AppendInference(ctx, topic, nonce.BlockHeight, &newInference2) s.Require().NoError(err) newAllInferences, err = k.GetInferencesAtBlock(ctx, topicId, nonce.BlockHeight) s.Require().NoError(err) @@ -3549,14 +3549,14 @@ func (s *KeeperTestSuite) TestAppendInference() { s.Require().Greater(updatedWorker2ScoreVal, ogWorker2ScoreVal, "worker2 score should go up given large ema value") s.Require().Greater(updatedWorker2ScoreVal, worker5OgScoreVal, "worker2 could not overtake worker5, but not in this epoch") // EMA score should be updated with the new time of update given that it was updated then - s.Require().Equal(blockHeightInferences, updatedWorker2Score.BlockHeight) + s.Require().Equal(nonce.BlockHeight, updatedWorker2Score.BlockHeight) // Ensure passive set participant can't update their score within the same epoch blockHeightInferences = blockHeightInferences + 1 // within the same epoch => no update newInference2 = types.Inference{ TopicId: topicId, BlockHeight: blockHeightInferences, Inferer: worker2, Value: alloraMath.MustNewDecFromString("0.52"), } - err = k.AppendInference(ctx, topic, blockHeightInferences, nonce.BlockHeight, &newInference2) + err = k.AppendInference(ctx, topic, nonce.BlockHeight, &newInference2) s.Require().Error(err, types.ErrCantUpdateEmaMoreThanOncePerWindow.Error()) // Confirm no change in EMA score newAllInferences, err = k.GetInferencesAtBlock(ctx, topicId, nonce.BlockHeight) @@ -3668,7 +3668,7 @@ func (s *KeeperTestSuite) TestAppendForecast() { topic, err := k.GetTopic(ctx, topicId) s.Require().NoError(err) blockHeightInferences = blockHeightInferences + topic.EpochLength - err = k.AppendForecast(ctx, topic, blockHeightInferences, nonce.BlockHeight, &newForecast) + err = k.AppendForecast(ctx, topic, nonce.BlockHeight, &newForecast) s.Require().NoError(err) newAllForecasts, err := k.GetForecastsAtBlock(ctx, topicId, nonce.BlockHeight) s.Require().NoError(err) @@ -3693,8 +3693,7 @@ func (s *KeeperTestSuite) TestAppendForecast() { }, }, } - blockHeightInferences = blockHeightInferences + topic.EpochLength - err = k.AppendForecast(ctx, topic, blockHeightInferences, nonce.BlockHeight, &newInference2) + err = k.AppendForecast(ctx, topic, nonce.BlockHeight, &newInference2) s.Require().NoError(err) newAllForecasts, err = k.GetForecastsAtBlock(ctx, topicId, nonce.BlockHeight) s.Require().NoError(err) @@ -3775,8 +3774,7 @@ func (s *KeeperTestSuite) TestAppendReputerLoss() { } topic, err := k.GetTopic(ctx, topicId) s.Require().NoError(err) - blockHeight = blockHeight + topic.EpochLength - err = k.AppendReputerLoss(ctx, topic, blockHeight, nonce.BlockHeight, &newReputerLoss) + err = k.AppendReputerLoss(ctx, topic, nonce.BlockHeight, &newReputerLoss) s.Require().NoError(err) newAllReputerLosses, err := k.GetReputerLossBundlesAtBlock(ctx, topicId, nonce.BlockHeight) s.Require().NoError(err) @@ -3795,8 +3793,7 @@ func (s *KeeperTestSuite) TestAppendReputerLoss() { TopicId: topicId, }, } - blockHeight = blockHeight + topic.EpochLength - err = k.AppendReputerLoss(ctx, topic, blockHeight, nonce.BlockHeight, &newReputerLoss2) + err = k.AppendReputerLoss(ctx, topic, nonce.BlockHeight, &newReputerLoss2) s.Require().NoError(err) newAllReputerLosses, err = k.GetReputerLossBundlesAtBlock(ctx, topicId, nonce.BlockHeight) s.Require().NoError(err) diff --git a/x/emissions/keeper/msgserver/msg_server_reputer_payload.go b/x/emissions/keeper/msgserver/msg_server_reputer_payload.go index 8ba052ae5..c598549b2 100644 --- a/x/emissions/keeper/msgserver/msg_server_reputer_payload.go +++ b/x/emissions/keeper/msgserver/msg_server_reputer_payload.go @@ -90,7 +90,7 @@ func (ms msgServer) InsertReputerPayload(ctx context.Context, msg *types.InsertR } sdkCtx := sdk.UnwrapSDKContext(ctx) - err = ms.k.AppendReputerLoss(sdkCtx, topic, blockHeight, nonce.ReputerNonce.BlockHeight, msg.ReputerValueBundle) + err = ms.k.AppendReputerLoss(sdkCtx, topic, nonce.ReputerNonce.BlockHeight, msg.ReputerValueBundle) if err != nil { return nil, err } diff --git a/x/emissions/keeper/msgserver/msg_server_worker_payload.go b/x/emissions/keeper/msgserver/msg_server_worker_payload.go index 586de4442..201e72384 100644 --- a/x/emissions/keeper/msgserver/msg_server_worker_payload.go +++ b/x/emissions/keeper/msgserver/msg_server_worker_payload.go @@ -87,7 +87,7 @@ func (ms msgServer) InsertWorkerPayload(ctx context.Context, msg *types.InsertWo "inferer not using the same topic as bundle") } - err = ms.k.AppendInference(sdkCtx, topic, blockHeight, nonce.BlockHeight, inference) + err = ms.k.AppendInference(sdkCtx, topic, nonce.BlockHeight, inference) if err != nil { return nil, errorsmod.Wrapf(err, "Error appending inference") } @@ -148,7 +148,7 @@ func (ms msgServer) InsertWorkerPayload(ctx context.Context, msg *types.InsertWo if len(acceptedForecastElements) > 0 { forecast.ForecastElements = acceptedForecastElements - err = ms.k.AppendForecast(sdkCtx, topic, blockHeight, nonce.BlockHeight, forecast) + err = ms.k.AppendForecast(sdkCtx, topic, nonce.BlockHeight, forecast) if err != nil { return nil, errorsmod.Wrapf(err, "Error appending forecast")