From 06e11ce2ab96d1da0c0eb35fded75b49d7cf584e Mon Sep 17 00:00:00 2001 From: Julien Robert Date: Fri, 10 Jun 2022 15:24:48 +0200 Subject: [PATCH 1/3] feat: add x/nft app wiring integration tests --- simapp/app.yaml | 2 +- testutil/network/network.go | 35 +++++++++++++++++++++++ x/nft/client/testutil/app.yaml | 46 +++++++++++++++++++++++++++++++ x/nft/client/testutil/cli_test.go | 13 +++++++++ 4 files changed, 95 insertions(+), 1 deletion(-) create mode 100644 x/nft/client/testutil/app.yaml diff --git a/simapp/app.yaml b/simapp/app.yaml index a522ff08e6dd..2403357bb910 100644 --- a/simapp/app.yaml +++ b/simapp/app.yaml @@ -114,4 +114,4 @@ modules: - name: genutil config: - "@type": cosmos.genutil.module.v1.Module \ No newline at end of file + "@type": cosmos.genutil.module.v1.Module diff --git a/testutil/network/network.go b/testutil/network/network.go index 815117cca1a9..adbc6b391b49 100644 --- a/testutil/network/network.go +++ b/testutil/network/network.go @@ -33,7 +33,9 @@ import ( "github.com/cosmos/cosmos-sdk/crypto/hd" "github.com/cosmos/cosmos-sdk/crypto/keyring" cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types" + "github.com/cosmos/cosmos-sdk/depinject" pruningtypes "github.com/cosmos/cosmos-sdk/pruning/types" + "github.com/cosmos/cosmos-sdk/runtime" "github.com/cosmos/cosmos-sdk/server" "github.com/cosmos/cosmos-sdk/server/api" srvconfig "github.com/cosmos/cosmos-sdk/server/config" @@ -128,6 +130,39 @@ func DefaultConfig() Config { } } +func DefaultConfigWithAppConfig(appConfig depinject.Config) (Config, error) { + cfg := DefaultConfig() + var appBuilder *runtime.AppBuilder + var msgServiceRouter *baseapp.MsgServiceRouter + + if err := depinject.Inject(appConfig, + &appBuilder, + &msgServiceRouter, + ); err != nil { + return Config{}, err + } + + cfg.GenesisState = appBuilder.DefaultGenesis() + cfg.AppConstructor = func(val Validator) servertypes.Application { + app := appBuilder.Build( + val.Ctx.Logger, + dbm.NewMemDB(), + nil, + msgServiceRouter, + baseapp.SetPruning(pruningtypes.NewPruningOptionsFromString(val.AppConfig.Pruning)), + baseapp.SetMinGasPrices(val.AppConfig.MinGasPrices), + ) + + if err := app.Load(true); err != nil { + panic(err) + } + + return app + } + + return cfg, nil +} + type ( // Network defines a local in-process testing network using SimApp. It can be // configured to start any number of validators, each with its own RPC and API diff --git a/x/nft/client/testutil/app.yaml b/x/nft/client/testutil/app.yaml new file mode 100644 index 000000000000..ff5f3ffc9b23 --- /dev/null +++ b/x/nft/client/testutil/app.yaml @@ -0,0 +1,46 @@ +modules: + - name: runtime + config: + "@type": cosmos.app.runtime.v1alpha1.Module + + app_name: NftApp + + begin_blockers: [staking, auth, bank, genutil, nft, params] + end_blockers: [staking, auth, bank, genutil, nft, params] + init_genesis: [auth, bank, staking, genutil, nft, params] + + - name: auth + config: + "@type": cosmos.auth.module.v1.Module + bech32_prefix: cosmos + module_account_permissions: + - account: fee_collector + - account: bonded_tokens_pool + permissions: [burner, staking] + - account: not_bonded_tokens_pool + permissions: [burner, staking] + - account: nft + + - name: bank + config: + "@type": cosmos.bank.module.v1.Module + + - name: params + config: + "@type": cosmos.params.module.v1.Module + + - name: tx + config: + "@type": cosmos.tx.module.v1.Module + + - name: nft + config: + "@type": cosmos.nft.module.v1.Module + + - name: staking + config: + "@type": cosmos.staking.module.v1.Module + + - name: genutil + config: + "@type": cosmos.genutil.module.v1.Module diff --git a/x/nft/client/testutil/cli_test.go b/x/nft/client/testutil/cli_test.go index 7f92bbeeff55..0686e794a56e 100644 --- a/x/nft/client/testutil/cli_test.go +++ b/x/nft/client/testutil/cli_test.go @@ -1,14 +1,27 @@ package testutil import ( + _ "embed" "testing" + "github.com/stretchr/testify/require" "github.com/stretchr/testify/suite" + "cosmossdk.io/core/appconfig" "github.com/cosmos/cosmos-sdk/testutil/network" ) +//go:embed app.yaml +var appConfig []byte + func TestIntegrationTestSuite(t *testing.T) { + cfg, err := network.DefaultConfigWithAppConfig(appconfig.LoadYAML(appConfig)) + require.NoError(t, err) + cfg.NumValidators = 1 + suite.Run(t, NewIntegrationTestSuite(cfg)) +} + +func TestIntegrationTestSuite_Legacy(t *testing.T) { cfg := network.DefaultConfig() cfg.NumValidators = 1 suite.Run(t, NewIntegrationTestSuite(cfg)) From 1679a6e6cc3046891022e94b3d2772e49798439d Mon Sep 17 00:00:00 2001 From: Julien Robert Date: Fri, 10 Jun 2022 15:27:57 +0200 Subject: [PATCH 2/3] updates --- x/nft/client/testutil/cli_test.go | 6 ------ 1 file changed, 6 deletions(-) diff --git a/x/nft/client/testutil/cli_test.go b/x/nft/client/testutil/cli_test.go index 0686e794a56e..141e3fdacd62 100644 --- a/x/nft/client/testutil/cli_test.go +++ b/x/nft/client/testutil/cli_test.go @@ -20,9 +20,3 @@ func TestIntegrationTestSuite(t *testing.T) { cfg.NumValidators = 1 suite.Run(t, NewIntegrationTestSuite(cfg)) } - -func TestIntegrationTestSuite_Legacy(t *testing.T) { - cfg := network.DefaultConfig() - cfg.NumValidators = 1 - suite.Run(t, NewIntegrationTestSuite(cfg)) -} From 2ba7fdc336178c28fc39b7280453bad67eedda3b Mon Sep 17 00:00:00 2001 From: Julien Robert Date: Fri, 10 Jun 2022 15:50:54 +0200 Subject: [PATCH 3/3] feedback --- x/nft/client/testutil/cli_test.go | 7 ++----- x/nft/{client => }/testutil/app.yaml | 0 x/nft/testutil/app_config.go | 12 ++++++++++++ 3 files changed, 14 insertions(+), 5 deletions(-) rename x/nft/{client => }/testutil/app.yaml (100%) create mode 100644 x/nft/testutil/app_config.go diff --git a/x/nft/client/testutil/cli_test.go b/x/nft/client/testutil/cli_test.go index 141e3fdacd62..12544d34a846 100644 --- a/x/nft/client/testutil/cli_test.go +++ b/x/nft/client/testutil/cli_test.go @@ -7,15 +7,12 @@ import ( "github.com/stretchr/testify/require" "github.com/stretchr/testify/suite" - "cosmossdk.io/core/appconfig" "github.com/cosmos/cosmos-sdk/testutil/network" + "github.com/cosmos/cosmos-sdk/x/nft/testutil" ) -//go:embed app.yaml -var appConfig []byte - func TestIntegrationTestSuite(t *testing.T) { - cfg, err := network.DefaultConfigWithAppConfig(appconfig.LoadYAML(appConfig)) + cfg, err := network.DefaultConfigWithAppConfig(testutil.AppConfig) require.NoError(t, err) cfg.NumValidators = 1 suite.Run(t, NewIntegrationTestSuite(cfg)) diff --git a/x/nft/client/testutil/app.yaml b/x/nft/testutil/app.yaml similarity index 100% rename from x/nft/client/testutil/app.yaml rename to x/nft/testutil/app.yaml diff --git a/x/nft/testutil/app_config.go b/x/nft/testutil/app_config.go new file mode 100644 index 000000000000..1f01697aa019 --- /dev/null +++ b/x/nft/testutil/app_config.go @@ -0,0 +1,12 @@ +package testutil + +import ( + _ "embed" + + "cosmossdk.io/core/appconfig" +) + +//go:embed app.yaml +var appConfig []byte + +var AppConfig = appconfig.LoadYAML(appConfig)