Skip to content

Commit

Permalink
fix(x/group): v2 migration (cosmos#16017)
Browse files Browse the repository at this point in the history
Co-authored-by: unknown unknown <unknown@unknown>
  • Loading branch information
testinginprod and unknown unknown authored May 3, 2023
1 parent d31f296 commit 1d03f41
Show file tree
Hide file tree
Showing 3 changed files with 32 additions and 23 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -201,6 +201,7 @@ Ref: https://keepachangelog.com/en/1.0.0/

### Bug Fixes

* (x/group) [#16017](https://github.com/cosmos/cosmos-sdk/pull/16017) Correctly apply account number in group v2 migration.
* (types) [#15691](https://github.com/cosmos/cosmos-sdk/pull/15691) Make Coin.Validate() check that .Amount is not nil
* (x/auth) [#15059](https://github.com/cosmos/cosmos-sdk/pull/15059) `ante.CountSubKeys` returns 0 when passing a nil `Pubkey`.
* (x/capability) [#15030](https://github.com/cosmos/cosmos-sdk/pull/15030) Prevent `x/capability` from consuming `GasMeter` gas during `InitMemStore`
Expand Down
6 changes: 6 additions & 0 deletions x/group/migrations/v2/migrate.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,12 @@ func Migrate(
return fmt.Errorf("failed to create new group policy account: %w", err)
}

// set account number
err = baseAccount.SetAccountNumber(oldAcc.GetAccountNumber())
if err != nil {
return err
}

// NOTE: we do not call NewAccount because we do not want to bump the account number

// set new account
Expand Down
48 changes: 25 additions & 23 deletions x/group/migrations/v2/migrate_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,11 @@ import (
)

var (
policies = []sdk.AccAddress{policyAddr1, policyAddr2, policyAddr3}
policyAddr1 = sdk.MustAccAddressFromBech32("cosmos1q32tjg5qm3n9fj8wjgpd7gl98prefntrckjkyvh8tntp7q33zj0s5tkjrk")
policyAddr2 = sdk.MustAccAddressFromBech32("cosmos1afk9zr2hn2jsac63h4hm60vl9z3e5u69gndzf7c99cqge3vzwjzsfwkgpd")
policyAddr3 = sdk.MustAccAddressFromBech32("cosmos1dlszg2sst9r69my4f84l3mj66zxcf3umcgujys30t84srg95dgvsmn3jeu")
accountAddr = sdk.AccAddress("addr2_______________")
policies = []sdk.AccAddress{policyAddr1, policyAddr2, policyAddr3}
policyAddr1 = sdk.MustAccAddressFromBech32("cosmos1q32tjg5qm3n9fj8wjgpd7gl98prefntrckjkyvh8tntp7q33zj0s5tkjrk")
policyAddr2 = sdk.MustAccAddressFromBech32("cosmos1afk9zr2hn2jsac63h4hm60vl9z3e5u69gndzf7c99cqge3vzwjzsfwkgpd")
policyAddr3 = sdk.MustAccAddressFromBech32("cosmos1dlszg2sst9r69my4f84l3mj66zxcf3umcgujys30t84srg95dgvsmn3jeu")
authorityAddr = sdk.AccAddress("authority")
)

func TestMigrate(t *testing.T) {
Expand All @@ -36,24 +36,23 @@ func TestMigrate(t *testing.T) {
tKey := storetypes.NewTransientStoreKey("transient_test")
ctx := testutil.DefaultContext(storeKey, tKey)

accountKeeper := createOldPolicyAccount(ctx, storeKey, cdc)
groupPolicyTable, groupPolicySeq, err := createGroupPolicies(ctx, storeKey, cdc)
oldAccs, accountKeeper := createOldPolicyAccount(ctx, storeKey, cdc, policies)
groupPolicyTable, groupPolicySeq, err := createGroupPolicies(ctx, storeKey, cdc, policies)
require.NoError(t, err)

oldAcc := accountKeeper.GetAccount(ctx, policyAddr1)

require.NoError(t, v2.Migrate(ctx, storeKey, accountKeeper, groupPolicySeq, groupPolicyTable))
newAcc := accountKeeper.GetAccount(ctx, policyAddr1)

require.NotEqual(t, oldAcc, newAcc)
require.True(t, func() bool { _, ok := oldAcc.(*authtypes.ModuleAccount); return ok }())
require.True(t, func() bool { _, ok := newAcc.(*authtypes.BaseAccount); return ok }())
require.Equal(t, oldAcc.GetAddress(), newAcc.GetAddress())
require.Equal(t, oldAcc.GetAccountNumber(), newAcc.GetAccountNumber())
require.Equal(t, newAcc.GetPubKey().Address().Bytes(), newAcc.GetAddress().Bytes())
for i, policyAddr := range policies {
oldAcc := oldAccs[i]
newAcc := accountKeeper.GetAccount(ctx, policyAddr)
require.NotEqual(t, oldAcc, newAcc)
require.True(t, func() bool { _, ok := newAcc.(*authtypes.BaseAccount); return ok }())
require.Equal(t, oldAcc.GetAddress(), newAcc.GetAddress())
require.Equal(t, int(oldAcc.GetAccountNumber()), int(newAcc.GetAccountNumber()))
require.Equal(t, newAcc.GetPubKey().Address().Bytes(), newAcc.GetAddress().Bytes())
}
}

func createGroupPolicies(ctx sdk.Context, storeKey storetypes.StoreKey, cdc codec.Codec) (orm.PrimaryKeyTable, orm.Sequence, error) {
func createGroupPolicies(ctx sdk.Context, storeKey storetypes.StoreKey, cdc codec.Codec, policies []sdk.AccAddress) (orm.PrimaryKeyTable, orm.Sequence, error) {
groupPolicyTable, err := orm.NewPrimaryKeyTable([2]byte{groupkeeper.GroupPolicyTablePrefix}, &group.GroupPolicyInfo{}, cdc)
if err != nil {
panic(err.Error())
Expand All @@ -62,7 +61,7 @@ func createGroupPolicies(ctx sdk.Context, storeKey storetypes.StoreKey, cdc code
groupPolicySeq := orm.NewSequence(v2.GroupPolicyTableSeqPrefix)

for _, policyAddr := range policies {
groupPolicyInfo, err := group.NewGroupPolicyInfo(policyAddr, 1, accountAddr, "", 1, group.NewPercentageDecisionPolicy("1", 1, 1), ctx.BlockTime())
groupPolicyInfo, err := group.NewGroupPolicyInfo(policyAddr, 1, authorityAddr, "", 1, group.NewPercentageDecisionPolicy("1", 1, 1), ctx.BlockTime())
if err != nil {
return orm.PrimaryKeyTable{}, orm.Sequence{}, err
}
Expand All @@ -78,17 +77,20 @@ func createGroupPolicies(ctx sdk.Context, storeKey storetypes.StoreKey, cdc code
}

// createOldPolicyAccount re-creates the group policy account using a module account
func createOldPolicyAccount(ctx sdk.Context, storeKey storetypes.StoreKey, cdc codec.Codec) group.AccountKeeper {
accountKeeper := authkeeper.NewAccountKeeper(cdc, runtime.NewKVStoreService(storeKey.(*storetypes.KVStoreKey)), authtypes.ProtoBaseAccount, nil, sdk.Bech32MainPrefix, accountAddr.String())
for _, policyAddr := range policies {
func createOldPolicyAccount(ctx sdk.Context, storeKey storetypes.StoreKey, cdc codec.Codec, policies []sdk.AccAddress) ([]*authtypes.ModuleAccount, group.AccountKeeper) {
accountKeeper := authkeeper.NewAccountKeeper(cdc, runtime.NewKVStoreService(storeKey.(*storetypes.KVStoreKey)), authtypes.ProtoBaseAccount, nil, sdk.Bech32MainPrefix, authorityAddr.String())

oldPolicyAccounts := make([]*authtypes.ModuleAccount, len(policies))
for i, policyAddr := range policies {
acc := accountKeeper.NewAccount(ctx, &authtypes.ModuleAccount{
BaseAccount: &authtypes.BaseAccount{
Address: policyAddr.String(),
},
Name: policyAddr.String(),
})
accountKeeper.SetAccount(ctx, acc)
oldPolicyAccounts[i] = acc.(*authtypes.ModuleAccount)
}

return accountKeeper
return oldPolicyAccounts, accountKeeper
}

0 comments on commit 1d03f41

Please sign in to comment.