From adf8b37fe3c5f085f2877e65534c43546158fda7 Mon Sep 17 00:00:00 2001 From: Marko Baricevic Date: Tue, 26 Nov 2024 12:02:44 +0100 Subject: [PATCH] fix pruning bug --- cmd/pruner.go | 62 +++++++++++++++++++++++++++++---------------------- 1 file changed, 35 insertions(+), 27 deletions(-) diff --git a/cmd/pruner.go b/cmd/pruner.go index c40bda7..bac16dc 100644 --- a/cmd/pruner.go +++ b/cmd/pruner.go @@ -4,18 +4,19 @@ import ( "context" "fmt" "path/filepath" + "sync" "github.com/cosmos/cosmos-sdk/types" sdk "github.com/cosmos/cosmos-sdk/types" authtypes "github.com/cosmos/cosmos-sdk/x/auth/types" - banktypes "github.com/cosmos/cosmos-sdk/x/bank/types" - crisistypes "github.com/cosmos/cosmos-sdk/x/crisis/types" - consensusparamtypes "github.com/cosmos/cosmos-sdk/x/consensus/types" authzkeeper "github.com/cosmos/cosmos-sdk/x/authz/keeper" - feegrant "github.com/cosmos/cosmos-sdk/x/feegrant" + banktypes "github.com/cosmos/cosmos-sdk/x/bank/types" capabilitytypes "github.com/cosmos/cosmos-sdk/x/capability/types" + consensusparamtypes "github.com/cosmos/cosmos-sdk/x/consensus/types" + crisistypes "github.com/cosmos/cosmos-sdk/x/crisis/types" distrtypes "github.com/cosmos/cosmos-sdk/x/distribution/types" evidencetypes "github.com/cosmos/cosmos-sdk/x/evidence/types" + feegrant "github.com/cosmos/cosmos-sdk/x/feegrant" govtypes "github.com/cosmos/cosmos-sdk/x/gov/types" minttypes "github.com/cosmos/cosmos-sdk/x/mint/types" paramstypes "github.com/cosmos/cosmos-sdk/x/params/types" @@ -204,8 +205,7 @@ func pruneAppState(home string) error { keys[key] = value } } else if app == "regen" { - regenKeys := types.NewKVStoreKeys( - ) + regenKeys := types.NewKVStoreKeys() for key, value := range regenKeys { keys[key] = value } @@ -259,8 +259,8 @@ func pruneAppState(home string) error { } } else if app == "juno" { junoKeys := types.NewKVStoreKeys( - "icahost", // icahosttypes.StoreKey, - "wasm", // wasm.StoreKey, + "icahost", // icahosttypes.StoreKey, + "wasm", // wasm.StoreKey, ) for key, value := range junoKeys { @@ -295,8 +295,8 @@ func pruneAppState(home string) error { // https://github.com/JackalLabs/canine-chain/blob/master/app/app.go#L347 jackalKeys := types.NewKVStoreKeys( // common modules - "wasm", // wasm.StoreKey, - "icahost", // icahosttypes.StoreKey, + "wasm", // wasm.StoreKey, + "icahost", // icahosttypes.StoreKey, // custom modules "icacontroller", // icacontrollertypes.StoreKey, https://github.com/cosmos/ibc-go/blob/main/modules/apps/27-interchain-accounts/controller/types/keys.go#L5 // intertx is a demo and not an officially supported IBC team implementation @@ -316,7 +316,7 @@ func pruneAppState(home string) error { } } else if app == "kichain" { kichainKeys := types.NewKVStoreKeys( - "wasm", // wasm.StoreKey, + "wasm", // wasm.StoreKey, ) for key, value := range kichainKeys { @@ -338,7 +338,7 @@ func pruneAppState(home string) error { } } else if app == "cheqd" { cheqdKeys := types.NewKVStoreKeys( - "cheqd", // cheqdtypes.StoreKey, + "cheqd", // cheqdtypes.StoreKey, ) for key, value := range cheqdKeys { @@ -346,9 +346,9 @@ func pruneAppState(home string) error { } } else if app == "stargaze" { stargazeKeys := types.NewKVStoreKeys( - "claim", // claimmoduletypes.StoreKey, - "alloc", // allocmoduletypes.StoreKey, - "wasm", // wasm.StoreKey, + "claim", // claimmoduletypes.StoreKey, + "alloc", // allocmoduletypes.StoreKey, + "wasm", // wasm.StoreKey, ) for key, value := range stargazeKeys { @@ -356,7 +356,7 @@ func pruneAppState(home string) error { } } else if app == "bandchain" { bandchainKeys := types.NewKVStoreKeys( - "oracle", // oracletypes.StoreKey, + "oracle", // oracletypes.StoreKey, ) for key, value := range bandchainKeys { @@ -364,7 +364,7 @@ func pruneAppState(home string) error { } } else if app == "chihuahua" { chihuahuaKeys := types.NewKVStoreKeys( - "wasm", // wasm.StoreKey, + "wasm", // wasm.StoreKey, ) for key, value := range chihuahuaKeys { @@ -372,7 +372,7 @@ func pruneAppState(home string) error { } } else if app == "bitcanna" { bitcannaKeys := types.NewKVStoreKeys( - "bcna", // bcnamoduletypes.StoreKey, + "bcna", // bcnamoduletypes.StoreKey, ) for key, value := range bitcannaKeys { @@ -399,7 +399,7 @@ func pruneAppState(home string) error { } } else if app == "vidulum" { vidulumKeys := types.NewKVStoreKeys( - "vidulum", // vidulummoduletypes.StoreKey, + "vidulum", // vidulummoduletypes.StoreKey, ) for key, value := range vidulumKeys { @@ -428,7 +428,7 @@ func pruneAppState(home string) error { } } else if app == "dig" { digKeys := types.NewKVStoreKeys( - "wasm", // wasm.StoreKey, + "wasm", // wasm.StoreKey, ) for key, value := range digKeys { @@ -463,7 +463,7 @@ func pruneAppState(home string) error { } } else if app == "fetchhub" { fetchhubKeys := types.NewKVStoreKeys( - "wasm", // wasm.StoreKey, + "wasm", // wasm.StoreKey, ) for key, value := range fetchhubKeys { @@ -471,7 +471,7 @@ func pruneAppState(home string) error { } } else if app == "persistent" { persistentKeys := types.NewKVStoreKeys( - "halving", // halving.StoreKey, + "halving", // halving.StoreKey, ) for key, value := range persistentKeys { @@ -527,22 +527,22 @@ func pruneAppState(home string) error { } } else if app == "umee" { umeeKeys := types.NewKVStoreKeys( - "gravity", // gravitytypes.StoreKey, + "gravity", // gravitytypes.StoreKey, ) for key, value := range umeeKeys { keys[key] = value } } else if app == "desmos" { - // https://github.com/desmos-labs/desmos/blob/master/app/app.go#L255 + // https://github.com/desmos-labs/desmos/blob/master/app/app.go#L255 desmosKeys := types.NewKVStoreKeys( // common modules - "wasm", // wasm.StoreKey, + "wasm", // wasm.StoreKey, // IBC modules "icacontroller", // icacontrollertypes.StoreKey, https://github.com/cosmos/ibc-go/blob/main/modules/apps/27-interchain-accounts/controller/types/keys.go#L5 - "icahost", // icahosttypes.StoreKey, + "icahost", // icahosttypes.StoreKey, // mainnet since v4.7.0 - "profiles", // profilestypes.StoreKey, + "profiles", // profilestypes.StoreKey, "relationships", // relationshipstypes.StoreKey, "subspaces", // subspacestypes.StoreKey, "posts", // poststypes.StoreKey, @@ -621,6 +621,8 @@ func pruneTMData(home string) error { pruneHeight := blockStore.Height() - int64(blocks) + wg := sync.WaitGroup{} + wg.Add(1) errs, _ := errgroup.WithContext(context.Background()) errs.Go(func() error { fmt.Println("pruning block store") @@ -635,6 +637,7 @@ func pruneTMData(home string) error { return err } + wg.Done() return nil }) @@ -650,6 +653,11 @@ func pruneTMData(home string) error { return err } + wg.Wait() + + stateDB.Close() + blockStore.Close() + return nil }