Skip to content
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

refactor(x/staking): Migrate Validators to use Collections #17123

Merged
merged 42 commits into from
Aug 28, 2023
Merged
Show file tree
Hide file tree
Changes from 12 commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
853f778
migrate Validators to use collections
likhita-809 Jul 25, 2023
37d1e02
Revert "migrate Validators to use collections"
likhita-809 Aug 8, 2023
5db4158
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 8, 2023
67c56df
wip
likhita-809 Aug 8, 2023
958d851
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 9, 2023
19c6504
fix tests
likhita-809 Aug 10, 2023
fe72691
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 10, 2023
37e1327
nit: improve comment
likhita-809 Aug 10, 2023
2a07dd6
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 11, 2023
216cc4d
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 16, 2023
5b8b650
fix test
likhita-809 Aug 16, 2023
66f8545
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 16, 2023
8887e80
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 18, 2023
6fd522b
fix compatibility
likhita-809 Aug 18, 2023
04a0fcf
fix integration tests
likhita-809 Aug 18, 2023
ed4b3c2
remove GetValidatorKey
likhita-809 Aug 18, 2023
2ab331f
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 18, 2023
d9d0de8
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 18, 2023
4212669
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 18, 2023
78ab84e
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 21, 2023
ac49b77
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 21, 2023
de3d4a5
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 21, 2023
6f91527
add diff test for validator
likhita-809 Aug 22, 2023
cf024f1
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 22, 2023
3cbc149
update validators to use Validator type instead of bytes
likhita-809 Aug 22, 2023
65b394b
remove panic
likhita-809 Aug 22, 2023
ca2b426
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 22, 2023
6b9d0f1
fix integration tests
likhita-809 Aug 23, 2023
627fc94
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 23, 2023
e08d012
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 23, 2023
5b57bdd
retain same error on collections not found error
likhita-809 Aug 23, 2023
7150383
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 23, 2023
3b4067d
cleanup
likhita-809 Aug 23, 2023
3679ee0
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 23, 2023
00a22be
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 24, 2023
571c6a2
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 24, 2023
ff5db27
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 28, 2023
e78ffa4
address review comments
likhita-809 Aug 28, 2023
5423c9e
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 28, 2023
e2cd0c1
Merge branch 'main' of https://github.com/cosmos/cosmos-sdk into likh…
likhita-809 Aug 28, 2023
225478d
revert changes from unbonding.go
likhita-809 Aug 28, 2023
260ec30
nits
likhita-809 Aug 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 8 additions & 8 deletions tests/integration/staking/keeper/deterministic_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -358,7 +358,7 @@ func TestGRPCValidator(t *testing.T) {
ValidatorAddr: val.OperatorAddress,
}

testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.Validator, 1915, false)
testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.Validator, 1912, false)
}

func TestGRPCValidators(t *testing.T) {
Expand All @@ -384,7 +384,7 @@ func TestGRPCValidators(t *testing.T) {
getStaticValidator(t, f)
getStaticValidator2(t, f)

testdata.DeterministicIterations(f.ctx, t, &stakingtypes.QueryValidatorsRequest{}, f.queryClient.Validators, 2862, false)
testdata.DeterministicIterations(f.ctx, t, &stakingtypes.QueryValidatorsRequest{}, f.queryClient.Validators, 2853, false)
}

func TestGRPCValidatorDelegations(t *testing.T) {
Expand Down Expand Up @@ -423,7 +423,7 @@ func TestGRPCValidatorDelegations(t *testing.T) {
ValidatorAddr: validator.OperatorAddress,
}

testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.ValidatorDelegations, 14475, false)
testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.ValidatorDelegations, 14466, false)
}

func TestGRPCValidatorUnbondingDelegations(t *testing.T) {
Expand Down Expand Up @@ -503,7 +503,7 @@ func TestGRPCDelegation(t *testing.T) {
DelegatorAddr: delegator1,
}

testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.Delegation, 4635, false)
testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.Delegation, 4632, false)
}

func TestGRPCUnbondingDelegation(t *testing.T) {
Expand Down Expand Up @@ -578,7 +578,7 @@ func TestGRPCDelegatorDelegations(t *testing.T) {
DelegatorAddr: delegator1,
}

testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.DelegatorDelegations, 4238, false)
testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.DelegatorDelegations, 4235, false)
}

func TestGRPCDelegatorValidator(t *testing.T) {
Expand Down Expand Up @@ -612,7 +612,7 @@ func TestGRPCDelegatorValidator(t *testing.T) {
ValidatorAddr: validator.OperatorAddress,
}

testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.DelegatorValidator, 3563, false)
testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.DelegatorValidator, 3560, false)
}

func TestGRPCDelegatorUnbondingDelegations(t *testing.T) {
Expand Down Expand Up @@ -743,7 +743,7 @@ func TestGRPCDelegatorValidators(t *testing.T) {
assert.NilError(t, err)

req := &stakingtypes.QueryDelegatorValidatorsRequest{DelegatorAddr: delegator1}
testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.DelegatorValidators, 3166, false)
testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.DelegatorValidators, 3163, false)
}

func TestGRPCPool(t *testing.T) {
Expand Down Expand Up @@ -823,7 +823,7 @@ func TestGRPCRedelegations(t *testing.T) {
DstValidatorAddr: validator2,
}

testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.Redelegations, 3920, false)
testdata.DeterministicIterations(f.ctx, t, req, f.queryClient.Redelegations, 3917, false)
}

func TestGRPCParams(t *testing.T) {
Expand Down
2 changes: 2 additions & 0 deletions x/staking/keeper/keeper.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ type Keeper struct {
UnbondingType collections.Map[uint64, uint64]
Delegations collections.Map[collections.Pair[sdk.AccAddress, sdk.ValAddress], types.Delegation]
UnbondingIndex collections.Map[uint64, []byte]
Validators collections.Map[sdk.ValAddress, []byte]
tac0turtle marked this conversation as resolved.
Show resolved Hide resolved
}

// NewKeeper creates a new staking Keeper instance
Expand Down Expand Up @@ -109,6 +110,7 @@ func NewKeeper(
),
UnbondingType: collections.NewMap(sb, types.UnbondingTypeKey, "unbonding_type", collections.Uint64Key, collections.Uint64Value),
UnbondingIndex: collections.NewMap(sb, types.UnbondingIndexKey, "unbonding_index", collections.Uint64Key, collections.BytesValue),
Validators: collections.NewMap(sb, types.ValidatorsKey, "validators", sdk.ValAddressKey, collections.BytesValue),
}

schema, err := sb.Build()
Expand Down
7 changes: 3 additions & 4 deletions x/staking/keeper/unbonding.go
Original file line number Diff line number Diff line change
Expand Up @@ -113,8 +113,6 @@ func (k Keeper) GetRedelegationByUnbondingID(ctx context.Context, id uint64) (re

// GetValidatorByUnbondingID returns the validator that is unbonding with a certain unbonding op ID
func (k Keeper) GetValidatorByUnbondingID(ctx context.Context, id uint64) (val types.Validator, err error) {
store := k.storeService.OpenKVStore(ctx)

valKey, err := k.UnbondingIndex.Get(ctx, id)
if err != nil {
if errors.Is(err, collections.ErrNotFound) {
Expand All @@ -127,8 +125,8 @@ func (k Keeper) GetValidatorByUnbondingID(ctx context.Context, id uint64) (val t
return types.Validator{}, types.ErrNoValidatorFound
}

value, err := store.Get(valKey)
if err != nil {
value, err := k.Validators.Get(ctx, valKey)
if err != nil && !errors.Is(err, collections.ErrNotFound) {
return types.Validator{}, err
}

Expand Down Expand Up @@ -203,6 +201,7 @@ func (k Keeper) SetValidatorByUnbondingID(ctx context.Context, val types.Validat
}

valKey := types.GetValidatorKey(valAddr)
valKey = valKey[2:] // leave prefix bytes and address length
if err = k.UnbondingIndex.Set(ctx, id, valKey); err != nil {
return err
}
Expand Down
15 changes: 6 additions & 9 deletions x/staking/keeper/validator.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,12 +22,10 @@ import (

// GetValidator gets a single validator
func (k Keeper) GetValidator(ctx context.Context, addr sdk.ValAddress) (validator types.Validator, err error) {
store := k.storeService.OpenKVStore(ctx)
value, err := store.Get(types.GetValidatorKey(addr))
if err != nil {
value, err := k.Validators.Get(ctx, addr)
if err != nil && !errors.Is(err, collections.ErrNotFound) {
return validator, err
}

if value == nil {
return validator, types.ErrNoValidatorFound
}
Expand Down Expand Up @@ -69,13 +67,12 @@ func (k Keeper) mustGetValidatorByConsAddr(ctx context.Context, consAddr sdk.Con

// SetValidator sets the main record holding validator details
func (k Keeper) SetValidator(ctx context.Context, validator types.Validator) error {
store := k.storeService.OpenKVStore(ctx)
bz := types.MustMarshalValidator(k.cdc, &validator)
str, err := k.ValidatorAddressCodec().StringToBytes(validator.GetOperator())
valBz, err := k.ValidatorAddressCodec().StringToBytes(validator.GetOperator())
if err != nil {
return err
panic(err)
github-advanced-security[bot] marked this conversation as resolved.
Fixed
Show resolved Hide resolved
}
return store.Set(types.GetValidatorKey(str), bz)
return k.Validators.Set(ctx, sdk.ValAddress(valBz), bz)
}

// SetValidatorByConsAddr sets a validator by conesensus address
Expand Down Expand Up @@ -233,7 +230,7 @@ func (k Keeper) RemoveValidator(ctx context.Context, address sdk.ValAddress) err

// delete the old validator record
store := k.storeService.OpenKVStore(ctx)
if err = store.Delete(types.GetValidatorKey(address)); err != nil {
if err = k.Validators.Remove(ctx, address); err != nil {
return err
}

Expand Down
7 changes: 6 additions & 1 deletion x/staking/migrations/v2/store_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import (
sdktestuil "github.com/cosmos/cosmos-sdk/testutil"
"github.com/cosmos/cosmos-sdk/testutil/testdata"
sdk "github.com/cosmos/cosmos-sdk/types"
sdkaddress "github.com/cosmos/cosmos-sdk/types/address"
v1 "github.com/cosmos/cosmos-sdk/x/staking/migrations/v1"
v2 "github.com/cosmos/cosmos-sdk/x/staking/migrations/v2"
"github.com/cosmos/cosmos-sdk/x/staking/testutil"
Expand Down Expand Up @@ -55,7 +56,7 @@ func TestStoreMigration(t *testing.T) {
{
"ValidatorsKey",
v1.GetValidatorKey(valAddr1),
types.GetValidatorKey(valAddr1),
getValidatorKey(valAddr1),
},
{
"ValidatorsByConsAddrKey",
Expand Down Expand Up @@ -139,3 +140,7 @@ func TestStoreMigration(t *testing.T) {
})
}
}

func getValidatorKey(operatorAddr sdk.ValAddress) []byte {
return append(types.ValidatorsKey, sdkaddress.MustLengthPrefix(operatorAddr)...)
}
4 changes: 0 additions & 4 deletions x/staking/simulation/decoder_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,8 +29,6 @@ func TestDecodeStore(t *testing.T) {
dec := simulation.NewDecodeStore(cdc)
bondTime := time.Now().UTC()

val, err := types.NewValidator(valAddr1.String(), delPk1, types.NewDescription("test", "test", "test", "test", "test"))
require.NoError(t, err)
ubd := types.NewUnbondingDelegation(delAddr1, valAddr1, 15, bondTime, math.OneInt(), 1, address.NewBech32Codec("cosmosvaloper"), address.NewBech32Codec("cosmos"))
red := types.NewRedelegation(delAddr1, valAddr1, valAddr1, 12, bondTime, math.OneInt(), math.LegacyOneDec(), 0, address.NewBech32Codec("cosmosvaloper"), address.NewBech32Codec("cosmos"))
oneIntBz, err := math.OneInt().Marshal()
Expand All @@ -39,7 +37,6 @@ func TestDecodeStore(t *testing.T) {
kvPairs := kv.Pairs{
Pairs: []kv.Pair{
{Key: types.LastTotalPowerKey, Value: oneIntBz},
{Key: types.GetValidatorKey(valAddr1), Value: cdc.MustMarshal(&val)},
{Key: types.LastValidatorPowerKey, Value: valAddr1.Bytes()},
{Key: types.GetUBDKey(delAddr1, valAddr1), Value: cdc.MustMarshal(&ubd)},
{Key: types.GetREDKey(delAddr1, valAddr1, valAddr1), Value: cdc.MustMarshal(&red)},
Expand All @@ -52,7 +49,6 @@ func TestDecodeStore(t *testing.T) {
expectedLog string
}{
{"LastTotalPower", fmt.Sprintf("%v\n%v", math.OneInt(), math.OneInt())},
{"Validator", fmt.Sprintf("%v\n%v", val, val)},
{"LastValidatorPower/ValidatorsByConsAddr/ValidatorsByPowerIndex", fmt.Sprintf("%v\n%v", valAddr1, valAddr1)},
{"UnbondingDelegation", fmt.Sprintf("%v\n%v", ubd, ubd)},
{"Redelegation", fmt.Sprintf("%v\n%v", red, red)},
Expand Down
2 changes: 1 addition & 1 deletion x/staking/types/keys.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ var (
LastValidatorPowerKey = []byte{0x11} // prefix for each key to a validator index, for bonded validators
LastTotalPowerKey = collections.NewPrefix(18) // prefix for the total power

ValidatorsKey = []byte{0x21} // prefix for each key to a validator
ValidatorsKey = collections.NewPrefix(33) // prefix for each key to a validator
ValidatorsByConsAddrKey = collections.NewPrefix(34) // prefix for each key to a validator index, by pubkey
ValidatorsByPowerIndexKey = []byte{0x23} // prefix for each key to a validator index, sorted by power

Expand Down