-
Notifications
You must be signed in to change notification settings - Fork 3.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix(x/distribution): fully deprecate distribution community pool #18539
Conversation
WalkthroughWalkthroughThe Cosmos SDK has undergone a significant refactoring, with a focus on the distribution module. Key changes include the deprecation of the Changes
TipsChat with CodeRabbit Bot (
|
I have tests and changelog to update and add, but i'd like a quick agreement on the concept of this PR before I continue. |
]; | ||
|
||
repeated cosmos.base.v1beta1.DecCoin decimal_pool = 2 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is the same as the community pool in terms of type, but renaming so that there is no confusion
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what is decimal pool suppose to signify?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That it gets the decimal coins, the scrums. This concept does not need to be known outside the module, but keeping the community pool as said above would have been confusing.
@@ -9,23 +9,24 @@ import ( | |||
) | |||
|
|||
// MigrateFunds migrates the distribution module funds to pool module | |||
func MigrateFunds(ctx sdk.Context, bankKeeper types.BankKeeper, feePool types.FeePool, macc, poolMacc sdk.ModuleAccountI) error { | |||
poolBal := sdk.NormalizeCoins(feePool.CommunityPool) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here the dust would stay in the community pool and as the previous migration was resetting it it could not match the supply and after the migration it would keep accruing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ACK. I haven't noticed this. Thanks for the PR @julienrbrt
Co-authored-by: Likhita Polavarapu <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 9
Configuration used: CodeRabbit UI
Files ignored due to filter (9)
- api/cosmos/nft/v1beta1/query_grpc.pb.go
- testutil/testdata/query.pb.go
- testutil/testdata/testdata.pb.go
- testutil/testdata/testpb/query_grpc.pb.go
- testutil/testdata/testpb/tx_grpc.pb.go
- testutil/testdata/tx.pb.go
- testutil/testdata/unknonwnproto.pb.go
- x/distribution/types/distribution.pb.go
- x/nft/query.pb.go
Files selected for processing (34)
- CHANGELOG.md (5 hunks)
- api/cosmos/distribution/v1beta1/distribution.pulsar.go (15 hunks)
- api/cosmos/nft/v1beta1/query.pulsar.go (10 hunks)
- proto/cosmos/distribution/v1beta1/distribution.proto (1 hunks)
- simapp/export.go (1 hunks)
- tests/integration/distribution/keeper/msg_server_test.go (1 hunks)
- testutil/testdata/testpb/query.pulsar.go (1 hunks)
- testutil/testdata/testpb/testdata.pulsar.go (1 hunks)
- testutil/testdata/testpb/tx.pulsar.go (1 hunks)
- testutil/testdata/testpb/unknonwnproto.pulsar.go (1 hunks)
- x/distribution/CHANGELOG.md (1 hunks)
- x/distribution/README.md (15 hunks)
- x/distribution/abci.go (1 hunks)
- x/distribution/keeper/allocation.go (4 hunks)
- x/distribution/keeper/allocation_test.go (5 hunks)
- x/distribution/keeper/delegation.go (3 hunks)
- x/distribution/keeper/genesis.go (3 hunks)
- x/distribution/keeper/hooks.go (2 hunks)
- x/distribution/keeper/invariants.go (1 hunks)
- x/distribution/keeper/keeper.go (1 hunks)
- x/distribution/keeper/migrations.go (2 hunks)
- x/distribution/keeper/msg_server.go (1 hunks)
- x/distribution/keeper/msg_server_test.go (1 hunks)
- x/distribution/keeper/validator.go (2 hunks)
- x/distribution/migrations/v4/migrate_funds.go (2 hunks)
- x/distribution/migrations/v4/migrate_funds_test.go (3 hunks)
- x/distribution/module.go (2 hunks)
- x/distribution/simulation/decoder_test.go (1 hunks)
- x/distribution/testutil/expected_keepers_mocks.go (1 hunks)
- x/distribution/types/expected_keepers.go (1 hunks)
- x/distribution/types/fee_pool.go (1 hunks)
- x/distribution/types/fee_pool_test.go (1 hunks)
- x/protocolpool/keeper/keeper.go (2 hunks)
- x/protocolpool/keeper/msg_server.go (1 hunks)
Files not summarized due to errors (1)
- api/cosmos/distribution/v1beta1/distribution.pulsar.go: Error: Message exceeds token limit
Files skipped from review due to trivial changes (7)
- api/cosmos/nft/v1beta1/query.pulsar.go
- testutil/testdata/testpb/query.pulsar.go
- testutil/testdata/testpb/testdata.pulsar.go
- x/distribution/README.md
- x/distribution/keeper/invariants.go
- x/distribution/simulation/decoder_test.go
- x/distribution/types/expected_keepers.go
Additional comments: 57
simapp/export.go (1)
- 126-141:
The changes correctly reflect the transition from using thecommunity_pool
to thedecimal_pool
. Ensure that all other parts of the codebase that interact with the fee pool are updated accordingly.x/protocolpool/keeper/msg_server.go (1)
- 93-102:
The changes to theCommunityPoolSpend
function reflect the updated logic and simplified logging. Ensure that the newDistributeFromCommunityPool
method is implemented and tested.x/distribution/keeper/msg_server_test.go (1)
- 260-262: The test
TestMsgCommunityPoolSpend
has been updated to expect theDistributeFromCommunityPool
method instead of the deprecatedDistributeFromFeePool
. Ensure that theDistributeFromCommunityPool
method is implemented with the same signature and that all tests are updated accordingly to reflect the new behavior.x/distribution/testutil/expected_keepers_mocks.go (1)
- 249-264: The renaming of
DistributeFromFeePool
toDistributeFromCommunityPool
in theMockPoolKeeper
struct and its recorder is consistent with the changes described in the pull request summary. This change reflects the deprecation of the community fee pool and the transition to using adecimal pool
. Ensure that all references to the old method name are updated across the codebase to prevent any integration issues.x/distribution/module.go (2)
31-31: The consensus version has been decreased from 5 to 4. This is a significant change that could potentially cause issues with state migrations and upgrades. Ensure that this change is intentional and that all necessary migration logic has been implemented to handle the version downgrade.
143-145: The
MigrateFundsToPool
migration function has been removed. Verify that this migration is no longer needed and that any funds previously managed by the community pool are correctly handled after this change.x/distribution/keeper/msg_server.go (1)
- 158-164: The method
DistributeFromCommunityPool
has been renamed toDistributeFromCommunityPool
, reflecting the shift from the deprecated community pool to the new decimal pool system. Ensure that the implementation ofDistributeFromCommunityPool
aligns with the new logic for handling the decimal pool and that all references to the old community pool have been updated accordingly.x/distribution/CHANGELOG.md (1)
- 1-64: - The changelog is well-structured and follows the guiding principles outlined in the comments. It provides a clear and detailed summary of the breaking changes, new features, and other significant alterations to the Cosmos SDK's distribution module.
- Ensure that all links to pull requests are correct and that the referenced changes match the descriptions provided.
- Verify that the migration of community pool funds to
x/protocolpool
and the introduction ofFeePool.DecimalPool
are well-documented and communicated to developers, as these are significant changes.- The changelog entries should be reviewed for accuracy and completeness by the team to ensure that all relevant changes are included and that there are no omissions or errors.
x/protocolpool/keeper/keeper.go (1)
- 75-82: The function
DistributeFromCommunityPool
has been correctly renamed and the comments have been updated to reflect the change from "feepool" to "community pool". This aligns with the summary of changes indicating the deprecation of the community fee pool and the transition to using adecimal pool
.x/distribution/types/fee_pool.go (2)
6-15:
The functionInitialFeePool
has been correctly updated to initialize the newDecimalPool
field.17-27:
TheValidateGenesis
method has been updated to validate the newDecimalPool
field. Ensure that the TODO comment is tracked in the project's issue tracker for future implementation.x/distribution/keeper/validator.go (2)
61-67: The code correctly fetches the
feePool
and checks for errors, which is good practice for robust error handling. However, it is important to ensure that theFeePool.Get
method is designed to handle the newdecimal_pool
field correctly.72-78: The logic for adding rewards to the
decimal_pool
and updating theoutstanding.Rewards
is sound. However, it is crucial to ensure that theFeePool.Set
andValidatorOutstandingRewards.Set
methods are atomic to prevent data races or inconsistencies, especially since this code may be part of a blockchain state transition.testutil/testdata/testpb/unknonwnproto.pulsar.go (1)
- 5-18: - The import of
v1beta1 "cosmossdk.io/api/cosmos/tx/v1beta1"
is added, which is likely needed for the changes in the distribution module. Ensure that this import is used in the code.
- The removal of
runtime "github.com/cosmos/cosmos-proto/runtime"
and_ "github.com/cosmos/gogoproto/gogoproto"
imports suggests that these packages are no longer used. Verify that removing these imports does not affect other parts of the code that may still require them.- The addition of imports for
io
,math
,reflect
,sort
, andsync
indicates new functionality that requires these packages. Confirm that these imports are indeed used in the code.- The reordering of imports is a good practice for readability and maintainability.
testutil/testdata/testpb/tx.pulsar.go (1)
- 4-15: - Removed imports for
io
,reflect
, andsync
are not shown in the hunk, ensure they are indeed removed as mentioned in the summary.
- Added import for
runtime
is correctly shown.- Specific imports from
cosmossdk.io
andcosmos
packages are not shown in the hunk, ensure they are indeed removed as mentioned in the summary.- The import block is reordered correctly according to the Go conventions (standard library -> third party -> own packages).
x/distribution/keeper/genesis.go (3)
14-19: The
InitGenesis
function has been updated to use the newFeePool
structure with theDecimalPool
field. Ensure that all other parts of the codebase that interact with theFeePool
are updated accordingly to prevent any runtime errors due to the changed structure.46-51: The error handling for setting the
PreviousProposer
is consistent with the rest of the function. However, ensure that thePreviousProposer
field is still relevant after the changes to the distribution module and that it is being used correctly elsewhere in the codebase.130-133: The addition of
data.FeePool.DecimalPool
tomoduleHoldings
replaces the previousCommunityPool
. This change aligns with the pull request's goal to deprecate the community pool. Verify that theDecimalPool
is correctly initialized and that the transition from the community pool to the decimal pool is handled in all relevant parts of the codebase.x/distribution/migrations/v4/migrate_funds_test.go (3)
1-4: The package name and import paths have been correctly updated to reflect the new module version.
16-22: The import paths have been updated to use the new module version
v4
. Ensure that all references to the old module version have been updated across the entire codebase.100-105: The test has been updated to capture the return value of
MigrateFunds
and check for errors, which is a good practice for error handling. However, ensure that theMigrateFunds
function has been properly updated to return a value that can be checked for errors.x/distribution/keeper/allocation_test.go (5)
151-153: The test checks if the
DecimalPool
is zero, which aligns with the new changes to the distribution module. However, ensure that theFeePool
struct no longer contains thecommunity_pool
field and that all references to it have been removed or replaced withdecimal_pool
throughout the codebase.168-171: The test simulates sending coins from the
fee_collector
module to thedistribution
module and then to theprotocolpool
module. Ensure that theSendCoinsFromModuleToModule
function is properly handling errors and that the amounts being sent are correctly calculated and validated.190-191: The test asserts the expected outstanding rewards for the second validator. Given the significant changes to the distribution process, ensure that the calculations for outstanding rewards are still accurate and that the new
decimal pool
mechanism is correctly factored into these calculations.193-195: The test checks if the
DecimalPool
is zero after token allocation. This is consistent with the new changes, but ensure that theFeePool
struct is correctly updated in the codebase and that theDecimalPool
is being managed as expected.309-312: The test simulates sending a large number of coins and checks if some amount is sent to the
protocolpool
. Ensure that theSendCoinsFromModuleToModule
function is robust against large transactions and that the logic for determining the amount sent to theprotocolpool
is correct and secure.x/distribution/keeper/allocation.go (5)
3-14: The import of the
sync
package (line 6) and theprotocolpooltypes
package (line 12) are new additions to support the concurrent processing and handling of the newdecimal_pool
. Ensure that these packages are used appropriately and that there are no data races introduced by the new concurrent logic.26-42: The logic to handle the case when
totalPreviousPower
is zero (lines 38-42) seems to be adding thefeesCollected
to theDecimalPool
without distributing them. This is a significant change in behavior and should be verified for correctness and consistency with the intended design of the newdecimal_pool
system.51-98: The use of goroutines and channels (lines 54-88) for concurrent processing of bonded votes is a new addition. Ensure that the concurrent logic is correctly implemented and that there are no data races or deadlocks. The use of
sync.WaitGroup
and error handling via channels is a good practice, but it's crucial to ensure that all goroutines complete and that errors are properly propagated.100-108: The logic to send the remaining rewards to the community pool and set the remainder in the fee pool (lines 100-108) is new. It's important to verify that the
SendCoinsFromModuleToModule
function is correctly implemented and that the remainder is correctly added to theDecimalPool
. Also, ensure that theFeePool
is correctly updated with the new remainder.176-194: The new function
SendDecimalPoolToCommunityPool
(lines 176-194) is responsible for transferring theDecimalPool
to the community pool. Verify that the logic correctly handles the transfer and that any remainder is correctly left in theDecimalPool
. Also, ensure that there are no issues with theSendCoinsFromModuleToModule
function call and that theFeePool
is correctly updated.x/distribution/migrations/v4/migrate_funds.go (3)
1-4:
The package name change from "funds" to "v4" is appropriate for versioning.11-32:
The changes toMigrateFunds
function correctly handle the migration of funds from the community pool to the decimal pool, including error handling and returning the newtypes.FeePool
structure.13-13:
The implementation now correctly handles the separation of the pool balance and the remainder usingTruncateDecimal
, which should address the issue of dust staying in the community pool as mentioned in the previous review.proto/cosmos/distribution/v1beta1/distribution.proto (1)
- 117-128: - The
FeePool
message has been correctly updated to deprecate thecommunity_pool
field and introduce thedecimal_pool
field. This aligns with the summary of changes indicating the transition from the community pool to the decimal pool.
- Ensure that all references to the
community_pool
in the codebase are updated to interact with thedecimal_pool
instead.- Verify that the
decimal_pool
is being used correctly in the logic of the distribution module, especially in theBeginBlocker
function and theAllocateTokens
function as mentioned in the summary.- The use of
repeated cosmos.base.v1beta1.DecCoin
for thedecimal_pool
field is consistent with the other DecCoin fields in the proto file, which is good for consistency.x/distribution/keeper/migrations.go (2)
1-7:
The change summary indicates that import statements were removed, but they are not visible in the provided hunk. Please ensure that the removal of imports does not affect other parts of the code that may rely on them.33-41:
The functionMigrate3to4
has been updated to include a call tomigrateFunds
. Ensure that this new function is thoroughly tested to prevent any issues during the migration process.CHANGELOG.md (5)
80-85:
The changelog entries provide clear information about the removal of certain functions due to AutoCLI migration and the removal of the Params module.127-132:
The changelog entries provide clear information about the use of collections forUnbondingType
andHistoricalInfo
, and the removal of associated functions.136-142:
The changelog entries provide clear information about the migration to collections and the removal of certain functions and types.148-153:
The changelog entries provide clear information about the changes to context creation,BurnCoins
function, and the removal of Amino-related functions.177-178:
The changelog entry provides clear information about the change in how the upgrade module handles the app version.api/cosmos/distribution/v1beta1/distribution.pulsar.go (15)
3706-3767: The code correctly defines a list implementation for the
decimal_pool
field. However, ensure that thecommunity_pool
field is no longer being used elsewhere in the codebase since it has been deprecated.3841-3846: The check for
len(x.DecimalPool) != 0
is correct. It ensures that thedecimal_pool
field is only processed if it contains elements.3864-3865: The switch case correctly checks for the presence of elements in the
decimal_pool
. This is consistent with the deprecation of thecommunity_pool
.3884-3885: Setting
x.DecimalPool
tonil
is a standard way to clear the slice. Ensure that this is the intended behavior and that there are no side effects elsewhere in the system.3908-3913: The code correctly handles the case where
x.DecimalPool
is not empty and provides a list value for it. This is part of the protobuf message reflection implementation.3938-3941: The assignment
x.DecimalPool = *clv.list
is correct, assuming thatclv.list
is a pointer to a slice ofDecCoin
. This is part of the protobuf message reflection implementation.3968-3973: The initialization of
x.DecimalPool
to an empty slice if it isnil
is a good practice to avoid nil pointer dereferences.3990-3992: Creating a new list with an empty slice for
decimal_pool
is correct and aligns with the protobuf message reflection implementation.4068-4073: The code correctly calculates the size needed for encoding the
decimal_pool
field. This is part of the protobuf message serialization process.4103-4117: The loop correctly marshals each
DecCoin
inx.DecimalPool
in reverse order. Ensure that the error handling is consistent with the rest of the codebase.4218-4251: The unmarshalling logic for the
decimal_pool
field is correct. It checks for the correct wire type and handles potential errors such as integer overflow and unexpected EOF.7066-7074: The
FeePool
struct has been updated to deprecate thecommunity_pool
field and introduce thedecimal_pool
field. Ensure that all references tocommunity_pool
in the codebase have been updated or removed.7097-7109: The getter methods for
community_pool
anddecimal_pool
are correctly marked as deprecated forcommunity_pool
and implemented fordecimal_pool
. Ensure that the deprecation ofcommunity_pool
is clearly communicated to developers and users.7456-7548: The protobuf file descriptor changes reflect the deprecation of
community_pool
and the introduction ofdecimal_pool
. Ensure that the corresponding documentation and changelogs are updated to reflect these changes.7587-7594: The type references for
decimal_pool
are correct and align with the protobuf definitions. Ensure that all related protobuf message types are correctly updated to reflect the use ofdecimal_pool
.
|
||
fp2 := types.FeePool{CommunityPool: sdk.DecCoins{{Denom: "stake", Amount: math.LegacyNewDec(-1)}}} | ||
require.NotNil(t, fp2.ValidateGenesis()) | ||
|
||
fp3 := types.FeePool{DecimalPool: sdk.DecCoins{{Denom: "stake", Amount: math.LegacyNewDec(-1)}}} | ||
require.NotNil(t, fp3.ValidateGenesis()) | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The new test case for fp3
is checking for a negative amount in the DecimalPool
, which is a valid test for ensuring that the ValidateGenesis
method correctly identifies invalid genesis states. However, it would be beneficial to also include a test case where the DecimalPool
has a valid positive amount to ensure that the ValidateGenesis
method correctly accepts a valid genesis state.
authKeeper types.AccountKeeper | ||
bankKeeper types.BankKeeper | ||
stakingKeeper types.StakingKeeper | ||
poolKeeper types.PoolKeeper // TODO: Needs to be removed in v0.53 | ||
poolKeeper types.PoolKeeper | ||
|
||
// the address capable of executing a MsgUpdateParams message. Typically, this | ||
// should be the x/gov module account. | ||
authority string | ||
|
||
Schema collections.Schema | ||
Params collections.Item[types.Params] | ||
Schema collections.Schema | ||
Params collections.Item[types.Params] | ||
// FeePool stores decimal tokens that cannot be yet distributed. | ||
// In the past it held the community pool, but it has been replaced by x/protocolpool. | ||
FeePool collections.Item[types.FeePool] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- The
poolKeeper
field is still present in theKeeper
struct, but the TODO comment indicating it needs to be removed has been deleted. If thepoolKeeper
is no longer needed due to the deprecation of the community pool, it should be removed from the struct to avoid confusion and potential misuse. - The
FeePool
field has been added to theKeeper
struct to store decimal tokens. Ensure that all interactions with theFeePool
are secure and correctly implemented throughout the module. - The comment on line 37 provides context but could be more descriptive about the transition from the community pool to the
decimal_pool
and its implications for the module's functionality.
// split into integral & remainder | ||
coins, remainder := commission.TruncateDecimal() | ||
|
||
// remainder to community pool | ||
// remainder to decimal pool | ||
feePool, err := h.k.FeePool.Get(ctx) | ||
if err != nil { | ||
return err | ||
} | ||
|
||
feePool.CommunityPool = feePool.CommunityPool.Add(remainder...) | ||
feePool.DecimalPool = feePool.DecimalPool.Add(remainder...) | ||
err = h.k.FeePool.Set(ctx, feePool) | ||
if err != nil { | ||
return err |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- The code retrieves the
FeePool
and adds theremainder
to theDecimalPool
. Ensure that theFeePool
struct has been updated to include theDecimalPool
field and that all references to theCommunityPool
have been properly replaced withDecimalPool
throughout the codebase. - Also, consider handling the case where
collections.ErrNotFound
is returned when getting theFeePool
. This would ensure that theDecimalPool
is initialized properly even if theFeePool
doesn't exist yet.
} | ||
} | ||
|
||
// Add outstanding to community pool | ||
// Add outstanding to decimal pool | ||
// The validator is removed only after it has no more delegations. | ||
// This operation sends only the remaining dust to the community pool. | ||
// This operation sends only the remaining dust to the decimal pool. | ||
feePool, err := h.k.FeePool.Get(ctx) | ||
if err != nil { | ||
return err | ||
} | ||
|
||
feePool.CommunityPool = feePool.CommunityPool.Add(outstanding...) | ||
feePool.DecimalPool = feePool.DecimalPool.Add(outstanding...) | ||
err = h.k.FeePool.Set(ctx, feePool) | ||
if err != nil { | ||
return err |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- Similar to the previous hunk, ensure that the
FeePool
struct includes theDecimalPool
field and that the transition fromCommunityPool
toDecimalPool
is consistent across the entire codebase. - Again, handle the potential
collections.ErrNotFound
error when getting theFeePool
to ensure proper initialization of theDecimalPool
.
} | ||
} | ||
|
||
// update the outstanding rewards and the community pool only if the | ||
// transaction was successful | ||
err = k.ValidatorOutstandingRewards.Set(ctx, sdk.ValAddress(valAddr), types.ValidatorOutstandingRewards{Rewards: outstanding.Sub(rewards)}) | ||
if err != nil { | ||
// update the outstanding rewards and the decimal pool only if the transaction was successful | ||
if err := k.ValidatorOutstandingRewards.Set(ctx, sdk.ValAddress(valAddr), types.ValidatorOutstandingRewards{Rewards: outstanding.Sub(rewards)}); err != nil { | ||
return nil, err | ||
} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note: This review was outside of the patch, so it was mapped to the patch with the greatest overlap. Original lines [248-280]
- The renaming of "community pool" to "decimal pool" in comments and code is consistent with the summary of changes. However, there is a potential issue with the error handling in the
withdrawDelegationRewards
function. The error fromk.FeePool.Set(ctx, feePool)
is not being checked immediately after the call, which could lead to a situation where the fee pool is not updated correctly but the function continues execution. This should be addressed to ensure that the function exits early in case of an error when setting the fee pool. - Additionally, the logic to transfer the remainder to the decimal pool is correct, but it's important to ensure that the
FeePool
struct and its methods are properly updated to handle the newDecimalPool
field as described in the summary of changes. - The use of goroutines and channels for concurrent processing in the
AllocateTokens
function is not shown in this hunk, but it's crucial to ensure that there are no data races when accessing shared resources like theFeePool
.
feePool.DecimalPool = feePool.DecimalPool.Add(remainder...)
+ if err = k.FeePool.Set(ctx, feePool); err != nil {
+ return nil, err
+ }
// check current balance is greater than initial balance | ||
curBalance := f.bankKeeper.GetAllBalances(f.sdkCtx, sdk.AccAddress(f.valAddr)) | ||
assert.Assert(t, initBalance.IsAllLTE(curBalance)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The test case "valid msg" in TestMsgWithdrawDelegatorReward
has removed the assertions related to checking rewards and outstanding rewards due to the deprecation of the community pool. However, the test still checks if the current balance is greater than the initial balance, which may not be a sufficient condition to ensure that rewards were correctly withdrawn and distributed. Consider adding more robust assertions to validate the new behavior with the decimal pool
.
x/distribution/abci.go
Outdated
if err := k.AllocateTokens(ctx, previousTotalPower, ctx.CometInfo().LastCommit.Votes); err != nil { | ||
return err | ||
} | ||
|
||
// every 1000 blocks send whole coins from decimal pool to community pool | ||
if ctx.BlockHeight()%1000 == 0 { | ||
if err := k.SendDecimalPoolToCommunityPool(ctx); err != nil { | ||
return err | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
- The new logic to transfer coins from the
decimal pool
to thecommunity pool
every 1000 blocks is correctly implemented. However, ensure that this change is well-documented and that any potential side effects are considered, especially regarding the timing and impact on the state. - Additionally, consider the implications of using a hardcoded value like
1000
for the block interval. It might be beneficial to make this configurable to allow for more flexibility in different network conditions or governance decisions. - Verify that the
SendDecimalPoolToCommunityPool
function handles all edge cases, such as when thedecimal pool
is empty or when the transfer fails due to network issues. - Ensure that the error handling is robust and that any errors are logged or monitored appropriately.
- Given the use of goroutines and channels in the
AllocateTokens
function, as mentioned in the summary, verify that there are no data races or concurrency issues when accessing shared resources, especially when theSendDecimalPoolToCommunityPool
function is called concurrently.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 1
Configuration used: CodeRabbit UI
Files selected for processing (3)
- x/distribution/keeper/allocation.go (4 hunks)
- x/distribution/keeper/migrations.go (2 hunks)
- x/protocolpool/keeper/keeper.go (2 hunks)
Files skipped from review due to trivial changes (1)
- x/protocolpool/keeper/keeper.go
Additional comments: 7
x/distribution/keeper/migrations.go (3)
1-7:
The removal of unused imports is a good practice for code cleanliness and readability.33-41:
The change in the function name from "MigrateFundsToPool" to "migrateFunds" and its usage in "Migrate3to4" is consistent and follows the Go naming convention for unexported functions.43-59:
The migration logic inmigrateFunds
appears to correctly handle the transfer of funds from the distribution module to the protocol pool module. Ensure that theFeePool.Get
andFeePool.Set
methods are correctly implemented to handle the newfeePool
structure.x/distribution/keeper/allocation.go (4)
3-14: The new import
protocolpooltypes
is added, ensure that it is used in the code and there are no unused imports.54-97: The use of goroutines and channels for concurrent processing is introduced. Ensure that the goroutines are properly synchronized using
WaitGroup
and that the error handling via channels is correctly implemented to avoid data races or deadlocks.100-107: The logic for sending the remaining rewards to the community pool and setting the remainder in the fee pool is implemented. Verify that the
TruncateDecimal
method correctly separates the integer and decimal parts and that the error handling is correct when sending coins and setting the fee pool.175-193: The new function
SendDecimalPoolToCommunityPool
is added to handle the transfer of the decimal pool to the community pool. Ensure that the logic correctly handles the case when the decimal pool is zero and that the remainder is correctly set in the fee pool after the transfer.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 0
Configuration used: CodeRabbit UI
Files selected for processing (1)
- tests/integration/distribution/keeper/msg_server_test.go (3 hunks)
Files skipped from review due to trivial changes (1)
- tests/integration/distribution/keeper/msg_server_test.go
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for this change @julienrbrt! Some comments:
- Let's make the commit subject more descriptive of what it is solving so:
fix(x/distribution): deprecate community pool in favour of decimalPool
- Please use a goroutine to waiting for the concurrent processing and error generation and then also use a cancellable context which will ensure that as soon as the first non-nil error is encountered, that we cease all work as intended, then avoid the need to process all the balances before failing
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 0
Configuration used: CodeRabbit UI
Files selected for processing (1)
- CHANGELOG.md (5 hunks)
Additional comments: 5
CHANGELOG.md (5)
81-86:
The changelog entries are clear and provide direct references to the associated pull requests for the removed methods and modules due to AutoCLI migration and Params module removal.128-133:
The changelog entries are clear and provide direct references to the associated pull requests for the use of collections and the removal of methods fromtypes
andKeeper
.137-143:
The changelog entries are clear and provide direct references to the associated pull requests for the migration to collections and the removal of methods and types.149-154:
The changelog entries are clear and provide direct references to the associated pull requests for the changes in context creation,BurnCoins
function, and deprecation of Amino-related functions.175-183:
The changelog entries are clear and provide direct references to the associated pull requests for the changes in command usage and the replacement ofHistoricalInfo
withHistoricalRecord
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 0
Configuration used: CodeRabbit UI
Files ignored due to filter (1)
- x/distribution/go.mod
Files selected for processing (1)
- x/distribution/keeper/allocation.go (4 hunks)
Additional comments: 5
x/distribution/keeper/allocation.go (5)
13-13: The addition of
golang.org/x/sync/errgroup
is for handling parallel processing, which is a new pattern in this codebase. Ensure that this pattern is safe and consistent with the rest of the codebase.55-100: The use of
errgroup.Group
for parallel processing is a significant change. Confirm that this concurrent processing does not introduce any non-deterministic behavior that could affect consensus.166-184: The new
SendDecimalPoolToCommunityPool
function manages the transfer of funds from thedecimal_pool
to the community pool. Ensure that this function is called at the appropriate times to maintain the intended behavior of the fee distribution.162-184: > Note: This review was outside the patches, so it was mapped to the patch with the greatest overlap. Original lines [103-164]
The
AllocateTokensToValidator
function appears unchanged in the provided hunk. Ensure that any changes to this function are consistent with the new fee distribution logic.
- 26-42: The logic for adding fees to the
DecimalPool
whentotalPreviousPower
is zero has been clarified by the user in a previous review. Ensure that this logic is still correctly implemented after the changes.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 0
Configuration used: CodeRabbit UI
Files selected for processing (1)
- x/distribution/keeper/allocation.go (4 hunks)
Additional comments: 3
x/distribution/keeper/allocation.go (3)
4-14: The addition of "golang.org/x/sync/errgroup" and "protocolpooltypes" imports aligns with the new concurrent processing logic and the interaction with the protocol pool module.
53-99: The use of errgroup and channels for concurrent processing of bonded votes and handling remaining rewards appears to be implemented correctly. Ensure that the channel is closed only after all goroutines have finished to avoid deadlocks or panics due to sending on a closed channel.
167-184: The new "SendDecimalPoolToCommunityPool" function correctly handles sending the decimal pool to the community pool and managing any remainder. The early return if the DecimalPool is zero is a good practice to avoid unnecessary processing.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
left a few comments, thank you for the cleanup
@@ -129,14 +128,10 @@ count is decremented. If the reference count hits zero, the historical record is | |||
|
|||
### FeePool | |||
|
|||
All globally tracked parameters for distribution are stored within | |||
`FeePool`. Rewards are collected and added to the reward pool and |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is this not the same as before?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No, it is stored in the distribution module, what makes it in the fee pool is only the too small coins parts that cannot be sent to the community pool
]; | ||
|
||
repeated cosmos.base.v1beta1.DecCoin decimal_pool = 2 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
what is decimal pool suppose to signify?
x/distribution/keeper/allocation.go
Outdated
if err != nil { | ||
return err | ||
} | ||
g.Go(func() error { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could we have some benchmarks on this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
could we get a short fuzz test for this function, if possible?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree it would be good to benchmark single threaded vs concurrent. the results might be surprising. iavl v0 & v1 is a single threaded reader, so if this func is i/o bound, there may not be too much wall clock improvement, in fact the coordination overhead could make things slower. iavl v2 scales well with concurrent reads, not sure that's relevant here though.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sure, will add 👍🏾
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 0
Configuration used: CodeRabbit UI
Files selected for processing (8)
- CHANGELOG.md (5 hunks)
- x/distribution/README.md (14 hunks)
- x/distribution/keeper/abci.go (3 hunks)
- x/distribution/keeper/allocation.go (4 hunks)
- x/distribution/keeper/allocation_test.go (5 hunks)
- x/distribution/keeper/migrations.go (2 hunks)
- x/distribution/module.go (3 hunks)
- x/distribution/types/keys.go (1 hunks)
Files skipped from review due to trivial changes (2)
- x/distribution/README.md
- x/distribution/types/keys.go
Additional comments: 18
CHANGELOG.md (5)
81-86: The changelog entries clearly communicate the removals and migrations due to AutoCLI migration and the deprecation of the params module. Ensure that dependent modules and applications are updated accordingly.
128-133: The migration to collections and the removal of functions are well-documented. It's important to verify that all references to these removed functions are updated in the codebase to prevent any broken functionality.
137-143: The changelog provides a comprehensive list of changes to the staking, authz, slashing modules, and types. It also includes significant changes to client commands. Developers should ensure that their code is compatible with these changes.
149-154: The changelog notes the deprecation of certain methods and the removal of Amino-related functions. This could impact legacy code, so it's crucial to check for any remaining usages and update them.
173-183: The changelog entry for the server and x/auth/vesting modules indicates command changes and clarifies the retraction of a previous version. It's important to note the state machine breaking changes for the upgrade and staking modules.
x/distribution/keeper/abci.go (2)
1-8: The import statement
cosmossdk.io/x/distribution/types
might need to be updated to reflect the new package structure if the types have also been moved or renamed.31-35: Verify that the
sendDecimalPoolToCommunityPool
function includes logic to check if the decimal pool has sufficient funds before attempting to transfer to the community pool to prevent potential errors.x/distribution/keeper/allocation.go (2)
4-11: The addition of the
errgroup
package and the use of goroutines and channels for concurrent processing in theAllocateTokens
function are significant changes. Ensure that all concurrency concerns have been addressed and that the state machine remains deterministic with these changes.166-184: The new
sendDecimalPoolToCommunityPool
function correctly checks if the decimal pool is zero before proceeding with sending funds to the community pool. This is a good practice to avoid unnecessary transactions.x/distribution/keeper/allocation_test.go (5)
151-153: The test correctly asserts that the
DecimalPool
is zero after the deprecation of the community pool. This aligns with the changes described in the summary.168-171: The test expectations for
bankKeeper
calls correctly reflect the new logic of sending coins to the protocol pool module, which is in line with the deprecation of the community pool and the introduction of the decimal pool.190-191: The test assertions for the validator's outstanding rewards are consistent with the expected values given the new allocation logic.
292-294: The test correctly asserts that the
DecimalPool
is zero, which is consistent with the changes to the community pool and the introduction of the decimal pool.309-312: The test expectations for
bankKeeper
calls correctly reflect the new logic of sending coins to the protocol pool module, which is in line with the deprecation of the community pool and the introduction of the decimal pool.x/distribution/keeper/migrations.go (1)
- 33-59: The changes in the migration function
Migrate3to4
and the helper functionmigrateFunds
correctly reflect the updates described in the summary. The renaming of the function and the update to the call tov4.MigrateFunds
are consistent with the intended changes. The comment on line 57 accurately describes the state offeePool
after the migration.x/distribution/module.go (3)
31-31: The downgrade of
ConsensusVersion
from 5 to 4 is acknowledged and seems intentional based on the previous comments and the summary provided.143-145: Removal of the migration from version 3 to 4 is acknowledged and aligns with the summary provided, which states the deprecation of the
MigrateFundsToPool
function.167-169: The modification in the
BeginBlock
function to callam.keeper.BeginBlocker(c)
is noted and appears to be a simplification of the function call.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 0
Configuration used: CodeRabbit UI
Files ignored due to filter (1)
- x/distribution/go.mod
Files selected for processing (1)
- CHANGELOG.md (5 hunks)
Additional comments: 5
CHANGELOG.md (5)
85-90: The removal of methods and migration to new modules as part of the AutoCLI migration is clearly documented.
132-137: The documentation of the migration to collections and the removal of methods from the
x/staking
module is well-noted.141-147: The changes related to the use of collections, migration of types, and removal of deprecated methods are correctly documented.
153-158: The updates to context creation, coin burning, and the removal of Amino-related functions are accurately captured.
177-187: The changes to command usage and the note on state machine breaking changes are properly documented, including the retraction of a previous release.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 0
Configuration used: CodeRabbit UI
Files ignored due to filter (1)
- x/distribution/go.mod
Files selected for processing (1)
- x/distribution/keeper/allocation.go (3 hunks)
Additional comments: 3
x/distribution/keeper/allocation.go (3)
31-40: The summary mentions replacing the direct modification of
feePool.CommunityPool
withk.FeePool.Set
, but the hunk shows modification offeePool.DecimalPool
. Please verify if the summary should refer toDecimalPool
instead ofCommunityPool
.67-89: > Note: This review was outside the patches, so it was mapped to the patch with the greatest overlap. Original lines [24-86]
The summary of the pull request mentions refactoring of the
AllocateTokens
function to use goroutines and channels for concurrent processing, but the hunk does not show any concurrency-related changes. Please verify if these changes are implemented elsewhere or if the summary is incorrect.
- 152-170: The summary of the pull request mentions a mechanism to transfer funds from the
decimal_pool
to the community pool every 1000 blocks, but thesendDecimalPoolToCommunityPool
method does not include any logic related to this condition. Please verify if this condition is implemented elsewhere or if the summary is incorrect.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Review Status
Actionable comments generated: 0
Configuration used: CodeRabbit UI
Files ignored due to filter (1)
- x/distribution/go.mod
Files selected for processing (1)
- CHANGELOG.md (5 hunks)
Additional comments: 6
CHANGELOG.md (6)
87-92: The changelog entries for
x/gov/testutil
,x/staking/testutil
,x/bank/testutil
, andapp
correctly document the removal of certain features and migration to new patterns. This aligns with the ongoing efforts to streamline the Cosmos SDK.134-139: The changelog entries for
x/staking
andclient
reflect the removal of deprecated methods and the adoption of new patterns, such as using collections forUnbondingType
andHistoricalInfo
. This is consistent with the summary's mention of general code clean-up and module updates.143-149: The changelog entries for
x/staking
,x/authz
,x/slashing
, andtypes
document the migration of state to collections and the removal of deprecated types and methods. This is in line with the summary's description of changes to various modules and the removal of outdated functionalities.155-160: The changelog entries for
types
,x/bank
, andclient
indicate significant changes to context handling, coin burning, and the removal of Amino-related functions. These changes are part of the broader updates mentioned in the summary, which aim to improve the SDK's efficiency and modernize its codebase.179-185: The changelog entry for
server
andx/auth/vesting
documents changes to command usage and argument ordering, which are user-facing changes that should be clearly communicated to developers. The entry forx/upgrade
andx/staking
reflects structural changes to the state machine, which are critical for developers to understand when upgrading their applications.143-149: > Note: This review was outside the patches, so it was mapped to the patch with the greatest overlap. Original lines [87-160]
The provided hunks do not include any changes related to the
x/distribution
module, which is a significant part of the summary. It is important to ensure that all notable changes, especially those involving deprecations and migrations, are documented in the changelog for developers' reference.
Description
I was reading distribution for #18236 (comment) and #18290 and noticed that the fee pool is still used and still accrues.
This PR fully deprecate the community fee pool and let x/protocolpool module account accrue instead.
We do still need a tracker for all those decimals being lost everytime.
Author Checklist
All items are required. Please add a note to the item if the item is not applicable and
please add links to any relevant follow up issues.
I have...
!
to the type prefix if API or client breaking changeCHANGELOG.md
make lint
andmake test
Reviewers Checklist
All items are required. Please add a note if the item is not applicable and please add
your handle next to the items reviewed if you only reviewed selected items.
I have...
!
in the type prefix if API or client breaking changeSummary by CodeRabbit
New Features
Enhancements
Documentation