forked from cerc-io/laconicd-deprecated
171 lines
4.9 KiB
Go
171 lines
4.9 KiB
Go
|
package keeper_test
|
||
|
|
||
|
import (
|
||
|
_ "embed"
|
||
|
"math/big"
|
||
|
"testing"
|
||
|
"time"
|
||
|
|
||
|
"github.com/stretchr/testify/require"
|
||
|
"github.com/stretchr/testify/suite"
|
||
|
|
||
|
"github.com/cosmos/cosmos-sdk/baseapp"
|
||
|
"github.com/cosmos/cosmos-sdk/client"
|
||
|
"github.com/cosmos/cosmos-sdk/codec"
|
||
|
"github.com/cosmos/cosmos-sdk/crypto/keyring"
|
||
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
||
|
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
||
|
stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types"
|
||
|
|
||
|
"github.com/tharsis/ethermint/app"
|
||
|
"github.com/tharsis/ethermint/crypto/ethsecp256k1"
|
||
|
"github.com/tharsis/ethermint/encoding"
|
||
|
"github.com/tharsis/ethermint/tests"
|
||
|
ethermint "github.com/tharsis/ethermint/types"
|
||
|
"github.com/tharsis/ethermint/x/feemarket/types"
|
||
|
|
||
|
"github.com/ethereum/go-ethereum/common"
|
||
|
ethtypes "github.com/ethereum/go-ethereum/core/types"
|
||
|
"github.com/ethereum/go-ethereum/crypto"
|
||
|
|
||
|
"github.com/tendermint/tendermint/crypto/tmhash"
|
||
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
||
|
tmversion "github.com/tendermint/tendermint/proto/tendermint/version"
|
||
|
"github.com/tendermint/tendermint/version"
|
||
|
)
|
||
|
|
||
|
type KeeperTestSuite struct {
|
||
|
suite.Suite
|
||
|
|
||
|
ctx sdk.Context
|
||
|
app *app.EthermintApp
|
||
|
queryClient types.QueryClient
|
||
|
address common.Address
|
||
|
consAddress sdk.ConsAddress
|
||
|
|
||
|
// for generate test tx
|
||
|
clientCtx client.Context
|
||
|
ethSigner ethtypes.Signer
|
||
|
|
||
|
appCodec codec.Codec
|
||
|
signer keyring.Signer
|
||
|
}
|
||
|
|
||
|
/// DoSetupTest setup test environment, it uses`require.TestingT` to support both `testing.T` and `testing.B`.
|
||
|
func (suite *KeeperTestSuite) DoSetupTest(t require.TestingT) {
|
||
|
checkTx := false
|
||
|
|
||
|
// account key
|
||
|
priv, err := ethsecp256k1.GenerateKey()
|
||
|
require.NoError(t, err)
|
||
|
suite.address = common.BytesToAddress(priv.PubKey().Address().Bytes())
|
||
|
suite.signer = tests.NewSigner(priv)
|
||
|
|
||
|
// consensus key
|
||
|
priv, err = ethsecp256k1.GenerateKey()
|
||
|
require.NoError(t, err)
|
||
|
suite.consAddress = sdk.ConsAddress(priv.PubKey().Address())
|
||
|
|
||
|
suite.app = app.Setup(checkTx, nil)
|
||
|
suite.ctx = suite.app.BaseApp.NewContext(checkTx, tmproto.Header{
|
||
|
Height: 1,
|
||
|
ChainID: "ethermint_9000-1",
|
||
|
Time: time.Now().UTC(),
|
||
|
ProposerAddress: suite.consAddress.Bytes(),
|
||
|
Version: tmversion.Consensus{
|
||
|
Block: version.BlockProtocol,
|
||
|
},
|
||
|
LastBlockId: tmproto.BlockID{
|
||
|
Hash: tmhash.Sum([]byte("block_id")),
|
||
|
PartSetHeader: tmproto.PartSetHeader{
|
||
|
Total: 11,
|
||
|
Hash: tmhash.Sum([]byte("partset_header")),
|
||
|
},
|
||
|
},
|
||
|
AppHash: tmhash.Sum([]byte("app")),
|
||
|
DataHash: tmhash.Sum([]byte("data")),
|
||
|
EvidenceHash: tmhash.Sum([]byte("evidence")),
|
||
|
ValidatorsHash: tmhash.Sum([]byte("validators")),
|
||
|
NextValidatorsHash: tmhash.Sum([]byte("next_validators")),
|
||
|
ConsensusHash: tmhash.Sum([]byte("consensus")),
|
||
|
LastResultsHash: tmhash.Sum([]byte("last_result")),
|
||
|
})
|
||
|
|
||
|
queryHelper := baseapp.NewQueryServerTestHelper(suite.ctx, suite.app.InterfaceRegistry())
|
||
|
types.RegisterQueryServer(queryHelper, suite.app.FeeMarketKeeper)
|
||
|
suite.queryClient = types.NewQueryClient(queryHelper)
|
||
|
|
||
|
acc := ðermint.EthAccount{
|
||
|
BaseAccount: authtypes.NewBaseAccount(sdk.AccAddress(suite.address.Bytes()), nil, 0, 0),
|
||
|
CodeHash: common.BytesToHash(crypto.Keccak256(nil)).String(),
|
||
|
}
|
||
|
|
||
|
suite.app.AccountKeeper.SetAccount(suite.ctx, acc)
|
||
|
|
||
|
valAddr := sdk.ValAddress(suite.address.Bytes())
|
||
|
validator, err := stakingtypes.NewValidator(valAddr, priv.PubKey(), stakingtypes.Description{})
|
||
|
err = suite.app.StakingKeeper.SetValidatorByConsAddr(suite.ctx, validator)
|
||
|
require.NoError(t, err)
|
||
|
err = suite.app.StakingKeeper.SetValidatorByConsAddr(suite.ctx, validator)
|
||
|
require.NoError(t, err)
|
||
|
suite.app.StakingKeeper.SetValidator(suite.ctx, validator)
|
||
|
|
||
|
encodingConfig := encoding.MakeConfig(app.ModuleBasics)
|
||
|
suite.clientCtx = client.Context{}.WithTxConfig(encodingConfig.TxConfig)
|
||
|
suite.ethSigner = ethtypes.LatestSignerForChainID(suite.app.EvmKeeper.ChainID())
|
||
|
suite.appCodec = encodingConfig.Marshaler
|
||
|
}
|
||
|
|
||
|
func (suite *KeeperTestSuite) SetupTest() {
|
||
|
suite.DoSetupTest(suite.T())
|
||
|
}
|
||
|
|
||
|
func TestKeeperTestSuite(t *testing.T) {
|
||
|
suite.Run(t, new(KeeperTestSuite))
|
||
|
}
|
||
|
|
||
|
func (suite *KeeperTestSuite) TestSetGetBlockGasUsed() {
|
||
|
testCases := []struct {
|
||
|
name string
|
||
|
malleate func()
|
||
|
expGas uint64
|
||
|
}{
|
||
|
{
|
||
|
"with last block given",
|
||
|
func() {
|
||
|
suite.app.FeeMarketKeeper.SetBlockGasUsed(suite.ctx, uint64(1000000))
|
||
|
},
|
||
|
uint64(1000000),
|
||
|
},
|
||
|
}
|
||
|
for _, tc := range testCases {
|
||
|
tc.malleate()
|
||
|
|
||
|
gas := suite.app.FeeMarketKeeper.GetBlockGasUsed(suite.ctx)
|
||
|
suite.Require().Equal(tc.expGas, gas, tc.name)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func (suite *KeeperTestSuite) TestSetGetGasFee() {
|
||
|
testCases := []struct {
|
||
|
name string
|
||
|
malleate func()
|
||
|
expFee *big.Int
|
||
|
}{
|
||
|
{
|
||
|
"with last block given",
|
||
|
func() {
|
||
|
suite.app.FeeMarketKeeper.SetBaseFee(suite.ctx, sdk.OneDec().BigInt())
|
||
|
},
|
||
|
sdk.OneDec().BigInt(),
|
||
|
},
|
||
|
}
|
||
|
|
||
|
for _, tc := range testCases {
|
||
|
tc.malleate()
|
||
|
|
||
|
fee := suite.app.FeeMarketKeeper.GetBaseFee(suite.ctx)
|
||
|
suite.Require().Equal(tc.expFee, fee, tc.name)
|
||
|
}
|
||
|
}
|