Skip to content

Commit

Permalink
fix upgrade
Browse files Browse the repository at this point in the history
  • Loading branch information
mmsqe committed Jan 4, 2024
1 parent 0050a33 commit 8446798
Show file tree
Hide file tree
Showing 9 changed files with 78 additions and 139 deletions.
9 changes: 9 additions & 0 deletions app/app.go
Original file line number Diff line number Diff line change
Expand Up @@ -568,6 +568,9 @@ func New(
supply.NewAppModule(app.SupplyKeeper),
nft.NewAppModule(appCodec, app.NFTKeeper, app.AccountKeeper, app.BankKeeper),
)
app.mm.SetOrderPreBlockers(
upgradetypes.ModuleName,
)

// During begin block slashing happens after distr.BeginBlocker so that
// there is nothing left over in the validator fee pool, so as to keep the
Expand Down Expand Up @@ -696,6 +699,7 @@ func New(

// initialize BaseApp
app.SetInitChainer(app.InitChainer)
app.SetPreBlocker(app.PreBlocker)
app.SetBeginBlocker(app.BeginBlocker)
anteHandler, err := NewAnteHandler(
HandlerOptions{
Expand Down Expand Up @@ -768,6 +772,11 @@ func (app *ChainApp) setPostHandler() {
// Name returns the name of the App
func (app *ChainApp) Name() string { return app.BaseApp.Name() }

// PreBlocker updates every pre begin block
func (app *ChainApp) PreBlocker(ctx sdk.Context, req abci.RequestBeginBlock) (sdk.ResponsePreBlock, error) {
return app.mm.PreBlock(ctx, req)
}

// BeginBlocker application updates every begin block
func (app *ChainApp) BeginBlocker(ctx sdk.Context, req abci.RequestBeginBlock) abci.ResponseBeginBlock {
// backport: https://github.com/cosmos/cosmos-sdk/pull/16639
Expand Down
91 changes: 0 additions & 91 deletions app/upgrades.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,23 +15,18 @@ import (
distrtypes "github.com/cosmos/cosmos-sdk/x/distribution/types"
govtypes "github.com/cosmos/cosmos-sdk/x/gov/types"
govv1 "github.com/cosmos/cosmos-sdk/x/gov/types/v1"
"github.com/cosmos/cosmos-sdk/x/group"
minttypes "github.com/cosmos/cosmos-sdk/x/mint/types"
paramstypes "github.com/cosmos/cosmos-sdk/x/params/types"
slashingtypes "github.com/cosmos/cosmos-sdk/x/slashing/types"
stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types"
upgradetypes "github.com/cosmos/cosmos-sdk/x/upgrade/types"
ica "github.com/cosmos/ibc-go/v7/modules/apps/27-interchain-accounts"
icacontrollertypes "github.com/cosmos/ibc-go/v7/modules/apps/27-interchain-accounts/controller/types"
icahosttypes "github.com/cosmos/ibc-go/v7/modules/apps/27-interchain-accounts/host/types"
icatypes "github.com/cosmos/ibc-go/v7/modules/apps/27-interchain-accounts/types"
ibcfeetypes "github.com/cosmos/ibc-go/v7/modules/apps/29-fee/types"
ibctransfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
clientkeeper "github.com/cosmos/ibc-go/v7/modules/core/02-client/keeper"
"github.com/cosmos/ibc-go/v7/modules/core/exported"
ibctmmigrations "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint/migrations"
icaauthmoduletypes "github.com/crypto-org-chain/chain-main/v4/x/icaauth/types"
nfttransfertypes "github.com/crypto-org-chain/chain-main/v4/x/nft-transfer/types"
)

func (app *ChainApp) RegisterUpgradeHandlers(cdc codec.BinaryCodec, clientKeeper clientkeeper.Keeper) {
Expand Down Expand Up @@ -82,107 +77,21 @@ func (app *ChainApp) RegisterUpgradeHandlers(cdc codec.BinaryCodec, clientKeeper

// Migrate Tendermint consensus parameters from x/params module to a dedicated x/consensus module.
baseapp.MigrateParams(ctx, baseAppLegacySS, &app.ConsensusParamsKeeper)

Check warning on line 79 in app/upgrades.go

View check run for this annotation

Codecov / codecov/patch

app/upgrades.go#L78-L79

Added lines #L78 - L79 were not covered by tests

// the minimal commission rate of 5% (0.05)
// (default is needed to be set because of SDK store migrations that set the param)
stakingtypes.DefaultMinCommissionRate = sdk.NewDecWithPrec(5, 2)

app.StakingKeeper.IterateValidators(ctx, func(index int64, val stakingtypes.ValidatorI) (stop bool) {
if val.GetCommission().LT(stakingtypes.DefaultMinCommissionRate) {
validator, found := app.StakingKeeper.GetValidator(ctx, val.GetOperator())
if !found {
ctx.Logger().Error("validator not found", val)
return true
}
ctx.Logger().Info("update validator's commission rate to a minimal one", val)
validator.Commission.Rate = stakingtypes.DefaultMinCommissionRate
if validator.Commission.MaxRate.LT(stakingtypes.DefaultMinCommissionRate) {
validator.Commission.MaxRate = stakingtypes.DefaultMinCommissionRate
}
app.StakingKeeper.SetValidator(ctx, validator)
}
return false
})

icaModule := app.mm.Modules[icatypes.ModuleName].(ica.AppModule)

// set the ICS27 consensus version so InitGenesis is not run
fromVM[icatypes.ModuleName] = icaModule.ConsensusVersion()

// create ICS27 Controller submodule params
controllerParams := icacontrollertypes.Params{
ControllerEnabled: false,
}

// create ICS27 Host submodule params
hostParams := icahosttypes.Params{
HostEnabled: false,
AllowMessages: []string{
"/cosmos.authz.v1beta1.MsgExec",
"/cosmos.authz.v1beta1.MsgGrant",
"/cosmos.authz.v1beta1.MsgRevoke",
"/cosmos.bank.v1beta1.MsgSend",
"/cosmos.bank.v1beta1.MsgMultiSend",
"/cosmos.distribution.v1beta1.MsgSetWithdrawAddress",
"/cosmos.distribution.v1beta1.MsgWithdrawValidatorCommission",
"/cosmos.distribution.v1beta1.MsgFundCommunityPool",
"/cosmos.distribution.v1beta1.MsgWithdrawDelegatorReward",
"/cosmos.gov.v1beta1.MsgVoteWeighted",
"/cosmos.gov.v1beta1.MsgSubmitProposal",
"/cosmos.gov.v1beta1.MsgDeposit",
"/cosmos.gov.v1beta1.MsgVote",
"/cosmos.staking.v1beta1.MsgCreateValidator",
"/cosmos.staking.v1beta1.MsgEditValidator",
"/cosmos.staking.v1beta1.MsgDelegate",
"/cosmos.staking.v1beta1.MsgUndelegate",
"/cosmos.staking.v1beta1.MsgBeginRedelegate",
"/cosmos.staking.v1beta1.MsgCancelUnbondingDelegation",
"/cosmos.slashing.v1beta1.MsgUnjail",
"/ibc.applications.transfer.v1.MsgTransfer",
"/chainmain.nft_transfer.v1.MsgTransfer",
"/chainmain.nft.v1.MsgBurnNFT",
"/chainmain.nft.v1.MsgEditNFT",
"/chainmain.nft.v1.MsgIssueDenom",
"/chainmain.nft.v1.MsgMintNFT",
"/chainmain.nft.v1.MsgTransferNFT",
},
}

ctx.Logger().Info("start to init interchain account module...")

// initialize ICS27 module
icaModule.InitModule(ctx, controllerParams, hostParams)

ctx.Logger().Info("start to run module migrations...")

return app.mm.RunMigrations(ctx, app.configurator, fromVM)
})

// testnets need to do a coordinated upgrade to keep in sync with current mainnet version
testnetPlanName := "v4.2.7-testnet"
app.UpgradeKeeper.SetUpgradeHandler(testnetPlanName, func(ctx sdk.Context, _ upgradetypes.Plan, fromVM module.VersionMap) (module.VersionMap, error) {
return app.mm.RunMigrations(ctx, app.configurator, fromVM)
})

upgradeInfo, err := app.UpgradeKeeper.ReadUpgradeInfoFromDisk()
if err != nil {
panic(fmt.Sprintf("failed to read upgrade info from disk %s", err))
}

if upgradeInfo.Name == planName && !app.UpgradeKeeper.IsSkipHeight(upgradeInfo.Height) {
storeUpgrades := storetypes.StoreUpgrades{
Added: []string{
group.ModuleName,
icacontrollertypes.StoreKey,
icahosttypes.StoreKey,
icaauthmoduletypes.StoreKey,
ibcfeetypes.StoreKey,
nfttransfertypes.StoreKey,
consensusparamtypes.StoreKey,
crisistypes.StoreKey,

Check warning on line 92 in app/upgrades.go

View check run for this annotation

Codecov / codecov/patch

app/upgrades.go#L91-L92

Added lines #L91 - L92 were not covered by tests
},
}

// configure store loader that checks if version == upgradeHeight and applies store upgrades
app.SetStoreLoader(upgradetypes.UpgradeStoreLoader(upgradeInfo.Height, &storeUpgrades))
}
Expand Down
50 changes: 26 additions & 24 deletions integration_tests/cosmoscli.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,31 +26,33 @@ def gov_propose_legacy(self, proposer, kind, proposal, no_validate=False, **kwar
mode = kwargs.get("broadcast_mode", "block")
event_query_tx = mode != "block"
if kind == "software-upgrade":
rsp = json.loads(
self.raw(
"tx",
"gov",
"submit-legacy-proposal",
kind,
proposal["name"],
"-y",
"--no-validate" if no_validate else None,
from_=proposer,
# content
title=proposal.get("title"),
description=proposal.get("description"),
upgrade_height=proposal.get("upgrade-height"),
upgrade_time=proposal.get("upgrade-time"),
upgrade_info=proposal.get("upgrade-info"),
deposit=proposal.get("deposit"),
# basic
home=self.data_dir,
node=self.node_rpc,
keyring_backend="test",
chain_id=self.chain_id,
**kwargs,
)
raw = self.raw(
"tx",
"gov",
"submit-legacy-proposal",
kind,
proposal["name"],
"-y",
"--no-validate" if no_validate else None,
from_=proposer,
# content
title=proposal.get("title"),
description=proposal.get("description"),
upgrade_height=proposal.get("upgrade-height"),
upgrade_time=proposal.get("upgrade-time"),
upgrade_info=proposal.get("upgrade-info", "info"),
deposit=proposal.get("deposit"),
# basic
home=self.data_dir,
node=self.node_rpc,
keyring_backend="test",
chain_id=self.chain_id,
**kwargs,
)
# skip success log info that breaks json.loads
brace_index = raw.index(b"{")
json_part = raw[brace_index:]
rsp = json.loads(json_part)
if rsp["code"] == 0 and event_query_tx:
rsp = self.event_query_tx_for(rsp["txhash"])
return rsp
Expand Down
8 changes: 4 additions & 4 deletions integration_tests/poetry.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion integration_tests/pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ pytest-github-actions-annotate-failures = "^0.1.7"
protobuf = "^3.20.2"
pyyaml = "^6.0.1"
python-dateutil = "^2.8.1"
pystarport = { git = "https://github.com/crypto-com/pystarport.git", branch = "main", rev = "1c3515549650497ff12fec4d2060a7e9cbaedf33" }
pystarport = { git = "https://github.com/mmsqe/pystarport.git", branch = "main", rev = "e4b75196ccd7aba037118a9407caaede2e72aac4" }
chainlibpy = "^2.2.0"

# manually upgrade to make hatchling build success in poetry2nix
Expand Down
33 changes: 16 additions & 17 deletions integration_tests/test_upgrade.py
Original file line number Diff line number Diff line change
Expand Up @@ -144,11 +144,12 @@ def test_cosmovisor(cosmovisor_cluster):

def propose_and_pass(cluster, kind, proposal, cosmos_sdk_47=True, **kwargs):
if cosmos_sdk_47:
kwargs.setdefault("output", "json")
rsp = cluster.gov_propose_legacy(

Check failure on line 148 in integration_tests/test_upgrade.py

View workflow job for this annotation

GitHub Actions / test-upgrade

test_cancel_upgrade TypeError: integration_tests.cosmoscli.ClusterCLI.gov_propose_legacy() got multiple values for keyword argument 'no_validate'
"community",
kind,
proposal,
broadcast_mode="sync",
no_validate=True,
**kwargs,
)
else:
Expand All @@ -169,10 +170,9 @@ def propose_and_pass(cluster, kind, proposal, cosmos_sdk_47=True, **kwargs):
proposal = cluster.query_proposal(proposal_id)
print("mm-proposal", proposal)
assert proposal["status"] == "PROPOSAL_STATUS_VOTING_PERIOD", proposal
wait = cosmos_sdk_47
rsp = cluster.gov_vote("validator", proposal_id, "yes", event_query_tx=wait)
rsp = cluster.gov_vote("validator", proposal_id, "yes", event_query_tx=False)
assert rsp["code"] == 0, rsp["raw_log"]
rsp = cluster.gov_vote("validator", proposal_id, "yes", i=1, event_query_tx=wait)
rsp = cluster.gov_vote("validator", proposal_id, "yes", i=1, event_query_tx=False)
assert rsp["code"] == 0, rsp["raw_log"]

proposal = cluster.query_proposal(proposal_id)
Expand All @@ -187,7 +187,6 @@ def propose_and_pass(cluster, kind, proposal, cosmos_sdk_47=True, **kwargs):

def upgrade(cluster, plan_name, target_height, cosmos_sdk_47=True):
print("upgrade height", target_height)

propose_and_pass(
cluster,
"software-upgrade",
Expand Down Expand Up @@ -217,14 +216,14 @@ def upgrade(cluster, plan_name, target_height, cosmos_sdk_47=True):
)

# check upgrade-info.json file is written
assert (
json.load((cluster.home(0) / "data/upgrade-info.json").open())
== json.load((cluster.home(1) / "data/upgrade-info.json").open())
== {
"name": plan_name,
"height": target_height,
}
)
js1 = json.load((cluster.home(0) / "data/upgrade-info.json").open())
js2 = json.load((cluster.home(1) / "data/upgrade-info.json").open())
expected = {
"name": plan_name,
"height": target_height,
}
assert js1 == js2
assert expected.items() <= js1.items()

# use the upgrade-test binary
edit_chain_program(
Expand Down Expand Up @@ -372,8 +371,8 @@ def assert_commission(adr, expected):
"creator": creator,
}, ev

target_height = cluster.block_height() + 30
upgrade(cluster, "v4.0.0", target_height, cosmos_sdk_47=False)
target_height = cluster.block_height() + 15
upgrade(cluster, "v4.2.0", target_height, cosmos_sdk_47=False)

cli = cluster.cosmos_cli()

Expand Down Expand Up @@ -415,8 +414,8 @@ def assert_commission(adr, expected):
assert_commission(validator1_operator_address, min_commission_rate)
assert_commission(validator2_operator_address, default_rate)

target_height = cluster.block_height() + 30
# upgrade(cluster, "sdk47-upgrade", target_height, cosmos_sdk_47=False)
target_height = cluster.block_height() + 15
upgrade(cluster, "sdk47-upgrade", target_height, cosmos_sdk_47=True)


def test_cancel_upgrade(cluster):
Expand Down
11 changes: 9 additions & 2 deletions integration_tests/upgrade-test.nix
Original file line number Diff line number Diff line change
Expand Up @@ -3,13 +3,20 @@ let
released = (import (builtins.fetchTarball "https://github.com/crypto-org-chain/chain-main/archive/v1.1.0.tar.gz") { }).chain-maind;
released2 = (import (builtins.fetchTarball "https://github.com/crypto-org-chain/chain-main/archive/v2.0.1.tar.gz") { }).chain-maind;
released3 = (import (builtins.fetchTarball "https://github.com/crypto-org-chain/chain-main/archive/v3.3.4.tar.gz") { }).chain-maind;
released4 = (import (builtins.fetchTarball "https://github.com/crypto-org-chain/chain-main/archive/v4.0.0-alpha3-croeseid.tar.gz") { }).chain-maind;
fetchFlake = repo: rev: (pkgs.flake-compat {
src = {
outPath = builtins.fetchTarball "https://github.com/${repo}/archive/${rev}.tar.gz";
inherit rev;
shortRev = builtins.substring 0 7 rev;
};
}).defaultNix;
released4 = (fetchFlake "crypto-org-chain/chain-main" "b3226f06fd2a236f9957304c4d83b0ea06ed2604").default;
current = pkgs.callPackage ../. { };
in
pkgs.linkFarm "upgrade-test-package" [
{ name = "genesis"; path = released; }
{ name = "v2.0.0"; path = released2; }
{ name = "v3.0.0"; path = released3; }
{ name = "v4.0.0"; path = released4; }
{ name = "v4.2.0"; path = released4; }
{ name = "sdk47-upgrade"; path = current; }
]
1 change: 1 addition & 0 deletions nix/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
import sources.nixpkgs {
overlays = [
(_: pkgs: {
flake-compat = import sources.flake-compat;
cosmovisor = pkgs.buildGoModule rec {
name = "cosmovisor";
src = sources.cosmos-sdk + "/cosmovisor";
Expand Down
12 changes: 12 additions & 0 deletions nix/sources.json
Original file line number Diff line number Diff line change
Expand Up @@ -46,5 +46,17 @@
"type": "tarball",
"url": "https://github.com/NixOS/nixpkgs/archive/90aa73fc8e1550b16d1ebdc436e48d9951f7989b.tar.gz",
"url_template": "https://github.com/<owner>/<repo>/archive/<rev>.tar.gz"
},
"flake-compat": {
"branch": "master",
"description": null,
"homepage": null,
"owner": "edolstra",
"repo": "flake-compat",
"rev": "b4a34015c698c7793d592d66adbab377907a2be8",
"sha256": "1qc703yg0babixi6wshn5wm2kgl5y1drcswgszh4xxzbrwkk9sv7",
"type": "tarball",
"url": "https://github.com/edolstra/flake-compat/archive/b4a34015c698c7793d592d66adbab377907a2be8.tar.gz",
"url_template": "https://github.com/<owner>/<repo>/archive/<rev>.tar.gz"
}
}

0 comments on commit 8446798

Please sign in to comment.