From 14a74d1179eb0f044e3b657306444456a834df6e Mon Sep 17 00:00:00 2001 From: zsystm Date: Fri, 20 Sep 2024 12:56:19 +0900 Subject: [PATCH 1/3] add test cases for genesis increase coverage to 83.3% --- .../evmengine/keeper/genesis_internal_test.go | 163 ++++++++++++++++++ 1 file changed, 163 insertions(+) create mode 100644 client/x/evmengine/keeper/genesis_internal_test.go diff --git a/client/x/evmengine/keeper/genesis_internal_test.go b/client/x/evmengine/keeper/genesis_internal_test.go new file mode 100644 index 00000000..37d91eb8 --- /dev/null +++ b/client/x/evmengine/keeper/genesis_internal_test.go @@ -0,0 +1,163 @@ +package keeper + +import ( + "context" + "testing" + + cmtproto "github.com/cometbft/cometbft/proto/tendermint/types" + sdk "github.com/cosmos/cosmos-sdk/types" + authtx "github.com/cosmos/cosmos-sdk/x/auth/tx" + "github.com/ethereum/go-ethereum/common" + "github.com/stretchr/testify/require" + + moduletestutil "github.com/piplabs/story/client/x/evmengine/testutil" + "github.com/piplabs/story/client/x/evmengine/types" + "github.com/piplabs/story/lib/ethclient/mock" + + "go.uber.org/mock/gomock" +) + +func createTestKeeper(t *testing.T) (context.Context, *Keeper) { + t.Helper() + + cdc := getCodec(t) + txConfig := authtx.NewTxConfig(cdc, nil) + mockEngine, err := newMockEngineAPI(0) + require.NoError(t, err) + + cmtAPI := newMockCometAPI(t, nil) + header := cmtproto.Header{Height: 1} + + ctrl := gomock.NewController(t) + mockClient := mock.NewMockClient(ctrl) + ak := moduletestutil.NewMockAccountKeeper(ctrl) + esk := moduletestutil.NewMockEvmStakingKeeper(ctrl) + uk := moduletestutil.NewMockUpgradeKeeper(ctrl) + + ctx, storeService := setupCtxStore(t, &header) + + keeper, err := NewKeeper(cdc, storeService, &mockEngine, mockClient, txConfig, ak, esk, uk) + require.NoError(t, err) + keeper.SetCometAPI(cmtAPI) + + return ctx, keeper +} + +func TestKeeper_InitGenesis(t *testing.T) { + t.Parallel() + dummyExecutionHead := common.HexToHash("0x047e24c3455107d87c68dffa307b3b7fa1877f3e9d7f30c7ee359f2eff3a75d9") + validParams := types.NewParams(dummyExecutionHead.Bytes()) + + tcs := []struct { + name string + gs func() *types.GenesisState + setup func(c context.Context, k *Keeper) + postStateCheck func(c context.Context, k *Keeper) + expectedError string + requirePanic bool + }{ + { + name: "pass", + gs: func() *types.GenesisState { + return &types.GenesisState{ + Params: validParams, + } + }, + postStateCheck: func(c context.Context, k *Keeper) { + params, err := k.GetParams(c) + require.NoError(t, err) + require.Equal(t, validParams, params) + }, + }, + { + name: "fail: invalid execution block hash", + gs: func() *types.GenesisState { + invalidParams := validParams + invalidParams.ExecutionBlockHash = []byte("invalid") + + return &types.GenesisState{ + Params: invalidParams, + } + }, + expectedError: "invalid execution block hash length", + }, + { + name: "panic: execution head already exists", + setup: func(c context.Context, k *Keeper) { + require.NoError(t, k.InsertGenesisHead(c, dummyExecutionHead.Bytes())) + }, + gs: func() *types.GenesisState { + return &types.GenesisState{ + Params: validParams, + } + }, + expectedError: "insert genesis head: unexpected genesis head id", + requirePanic: true, + }, + } + + for _, tc := range tcs { + t.Run(tc.name, func(t *testing.T) { + t.Parallel() + ctx, keeper := createTestKeeper(t) + if tc.setup != nil { + tc.setup(ctx, keeper) + } + if tc.requirePanic { + require.PanicsWithError(t, tc.expectedError, func() { + keeper.InitGenesis(ctx, tc.gs()) + }) + } else { + err := keeper.InitGenesis(ctx, tc.gs()) + if tc.expectedError != "" { + require.Error(t, err) + require.Contains(t, err.Error(), tc.expectedError) + } else { + require.NoError(t, err) + tc.postStateCheck(ctx, keeper) + } + } + }) + } +} + +func TestKeeper_ExportGenesis(t *testing.T) { + t.Parallel() + dummyExecutionHead := common.HexToHash("0x047e24c3455107d87c68dffa307b3b7fa1877f3e9d7f30c7ee359f2eff3a75d9") + validParams := types.NewParams(dummyExecutionHead.Bytes()) + + tcs := []struct { + name string + setup func(c context.Context, k *Keeper) + postStateCheck func(c context.Context, k *Keeper) + }{ + { + name: "pass", + setup: func(c context.Context, k *Keeper) { + require.NoError(t, k.SetParams(c, validParams)) + }, + postStateCheck: func(c context.Context, k *Keeper) { + gs := k.ExportGenesis(sdk.UnwrapSDKContext(c)) + require.Equal(t, validParams, gs.Params) + }, + }, + { + name: "pass: default params", + postStateCheck: func(c context.Context, k *Keeper) { + gs := k.ExportGenesis(sdk.UnwrapSDKContext(c)) + require.Equal(t, types.DefaultParams(), gs.Params) + }, + }, + } + + for _, tc := range tcs { + t.Run(tc.name, func(t *testing.T) { + t.Parallel() + ctx, keeper := createTestKeeper(t) + if tc.setup != nil { + tc.setup(ctx, keeper) + } + tc.postStateCheck(ctx, keeper) + }) + } +} From caafe45702ab75c7205d52ac56690e5174cfdb0f Mon Sep 17 00:00:00 2001 From: zsystm Date: Fri, 20 Sep 2024 13:02:43 +0900 Subject: [PATCH 2/3] fix ci --- client/x/evmengine/keeper/genesis_internal_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/client/x/evmengine/keeper/genesis_internal_test.go b/client/x/evmengine/keeper/genesis_internal_test.go index 37d91eb8..9a5ac4d6 100644 --- a/client/x/evmengine/keeper/genesis_internal_test.go +++ b/client/x/evmengine/keeper/genesis_internal_test.go @@ -105,7 +105,7 @@ func TestKeeper_InitGenesis(t *testing.T) { } if tc.requirePanic { require.PanicsWithError(t, tc.expectedError, func() { - keeper.InitGenesis(ctx, tc.gs()) + _ = keeper.InitGenesis(ctx, tc.gs()) }) } else { err := keeper.InitGenesis(ctx, tc.gs()) From 95b2020f7db24e1a17762ef7e9e5098fbf3dbcdb Mon Sep 17 00:00:00 2001 From: zsystm Date: Tue, 24 Sep 2024 14:41:45 +0900 Subject: [PATCH 3/3] move common function to keeper_internal_test.go --- client/x/evmengine/keeper/db_internal_test.go | 28 ---------------- .../evmengine/keeper/genesis_internal_test.go | 32 ------------------- .../evmengine/keeper/keeper_internal_test.go | 26 +++++++++++++++ 3 files changed, 26 insertions(+), 60 deletions(-) diff --git a/client/x/evmengine/keeper/db_internal_test.go b/client/x/evmengine/keeper/db_internal_test.go index a34a784d..32d0eeda 100644 --- a/client/x/evmengine/keeper/db_internal_test.go +++ b/client/x/evmengine/keeper/db_internal_test.go @@ -3,39 +3,11 @@ package keeper import ( "testing" - sdk "github.com/cosmos/cosmos-sdk/types" - authtx "github.com/cosmos/cosmos-sdk/x/auth/tx" "github.com/ethereum/go-ethereum/beacon/engine" "github.com/ethereum/go-ethereum/common" "github.com/stretchr/testify/require" - - moduletestutil "github.com/piplabs/story/client/x/evmengine/testutil" - "github.com/piplabs/story/lib/ethclient/mock" - - "go.uber.org/mock/gomock" ) -func createTestKeeper(t *testing.T) (sdk.Context, *Keeper) { - t.Helper() - cdc := getCodec(t) - txConfig := authtx.NewTxConfig(cdc, nil) - - mockEngine, err := newMockEngineAPI(0) - require.NoError(t, err) - - ctrl := gomock.NewController(t) - mockClient := mock.NewMockClient(ctrl) - ak := moduletestutil.NewMockAccountKeeper(ctrl) - esk := moduletestutil.NewMockEvmStakingKeeper(ctrl) - uk := moduletestutil.NewMockUpgradeKeeper(ctrl) - ctx, storeService := setupCtxStore(t, nil) - ctx = ctx.WithExecMode(sdk.ExecModeFinalize) - keeper, err := NewKeeper(cdc, storeService, &mockEngine, mockClient, txConfig, ak, esk, uk) - require.NoError(t, err) - - return ctx, keeper -} - func TestKeeper_InsertGenesisHead(t *testing.T) { t.Parallel() diff --git a/client/x/evmengine/keeper/genesis_internal_test.go b/client/x/evmengine/keeper/genesis_internal_test.go index 9a5ac4d6..1dd7ef8e 100644 --- a/client/x/evmengine/keeper/genesis_internal_test.go +++ b/client/x/evmengine/keeper/genesis_internal_test.go @@ -4,45 +4,13 @@ import ( "context" "testing" - cmtproto "github.com/cometbft/cometbft/proto/tendermint/types" sdk "github.com/cosmos/cosmos-sdk/types" - authtx "github.com/cosmos/cosmos-sdk/x/auth/tx" "github.com/ethereum/go-ethereum/common" "github.com/stretchr/testify/require" - moduletestutil "github.com/piplabs/story/client/x/evmengine/testutil" "github.com/piplabs/story/client/x/evmengine/types" - "github.com/piplabs/story/lib/ethclient/mock" - - "go.uber.org/mock/gomock" ) -func createTestKeeper(t *testing.T) (context.Context, *Keeper) { - t.Helper() - - cdc := getCodec(t) - txConfig := authtx.NewTxConfig(cdc, nil) - mockEngine, err := newMockEngineAPI(0) - require.NoError(t, err) - - cmtAPI := newMockCometAPI(t, nil) - header := cmtproto.Header{Height: 1} - - ctrl := gomock.NewController(t) - mockClient := mock.NewMockClient(ctrl) - ak := moduletestutil.NewMockAccountKeeper(ctrl) - esk := moduletestutil.NewMockEvmStakingKeeper(ctrl) - uk := moduletestutil.NewMockUpgradeKeeper(ctrl) - - ctx, storeService := setupCtxStore(t, &header) - - keeper, err := NewKeeper(cdc, storeService, &mockEngine, mockClient, txConfig, ak, esk, uk) - require.NoError(t, err) - keeper.SetCometAPI(cmtAPI) - - return ctx, keeper -} - func TestKeeper_InitGenesis(t *testing.T) { t.Parallel() dummyExecutionHead := common.HexToHash("0x047e24c3455107d87c68dffa307b3b7fa1877f3e9d7f30c7ee359f2eff3a75d9") diff --git a/client/x/evmengine/keeper/keeper_internal_test.go b/client/x/evmengine/keeper/keeper_internal_test.go index 311c7557..ccda9907 100644 --- a/client/x/evmengine/keeper/keeper_internal_test.go +++ b/client/x/evmengine/keeper/keeper_internal_test.go @@ -35,6 +35,32 @@ type args struct { header func(height int64, address []byte) cmtproto.Header } +func createTestKeeper(t *testing.T) (context.Context, *Keeper) { + t.Helper() + + cdc := getCodec(t) + txConfig := authtx.NewTxConfig(cdc, nil) + mockEngine, err := newMockEngineAPI(0) + require.NoError(t, err) + + cmtAPI := newMockCometAPI(t, nil) + header := cmtproto.Header{Height: 1} + + ctrl := gomock.NewController(t) + mockClient := mock.NewMockClient(ctrl) + ak := moduletestutil.NewMockAccountKeeper(ctrl) + esk := moduletestutil.NewMockEvmStakingKeeper(ctrl) + uk := moduletestutil.NewMockUpgradeKeeper(ctrl) + + ctx, storeService := setupCtxStore(t, &header) + + keeper, err := NewKeeper(cdc, storeService, &mockEngine, mockClient, txConfig, ak, esk, uk) + require.NoError(t, err) + keeper.SetCometAPI(cmtAPI) + + return ctx, keeper +} + func createKeeper(t *testing.T, args args) (sdk.Context, *mockCometAPI, *Keeper) { t.Helper()