forked from cerc-io/laconicd-deprecated
9cbb4dcf6d
* changelog v0.4.0 * stargate: types changes * msg and handler changes * validation * fixes * more fixes * more test fixes * changelog * changelog * lint * rm comment * lint * redundant if condition
62 lines
1.8 KiB
Go
62 lines
1.8 KiB
Go
package keeper_test
|
|
|
|
import (
|
|
"math/big"
|
|
|
|
"github.com/cosmos/ethermint/x/evm/types"
|
|
ethtypes "github.com/ethereum/go-ethereum/core/types"
|
|
|
|
abci "github.com/tendermint/tendermint/abci/types"
|
|
)
|
|
|
|
func (suite *KeeperTestSuite) TestQuerier() {
|
|
|
|
testCases := []struct {
|
|
msg string
|
|
path []string
|
|
malleate func()
|
|
expPass bool
|
|
}{
|
|
{"balance", []string{types.QueryBalance, addrHex}, func() {
|
|
suite.app.EvmKeeper.SetBalance(suite.ctx, suite.address, big.NewInt(5))
|
|
}, true},
|
|
// {"balance fail", []string{types.QueryBalance, "0x01232"}, func() {}, false},
|
|
{"block number", []string{types.QueryBlockNumber, "0x0"}, func() {}, true},
|
|
{"storage", []string{types.QueryStorage, "0x0", "0x0"}, func() {}, true},
|
|
{"code", []string{types.QueryCode, "0x0"}, func() {}, true},
|
|
{"hash to height", []string{types.QueryHashToHeight, hex}, func() {
|
|
suite.app.EvmKeeper.SetBlockHash(suite.ctx, hash, 8)
|
|
}, true},
|
|
{"tx logs", []string{types.QueryTransactionLogs, "0x0"}, func() {}, true},
|
|
{"bloom", []string{types.QueryBloom, "4"}, func() {
|
|
testBloom := ethtypes.BytesToBloom([]byte{0x1, 0x3})
|
|
suite.app.EvmKeeper.SetBlockBloom(suite.ctx, 4, testBloom)
|
|
}, true},
|
|
{"logs", []string{types.QueryLogs, "0x0"}, func() {}, true},
|
|
{"account", []string{types.QueryAccount, "0x0"}, func() {}, true},
|
|
{"unknown request", []string{"other"}, func() {}, false},
|
|
}
|
|
|
|
for i, tc := range testCases {
|
|
suite.Run("", func() {
|
|
//nolint
|
|
tc := tc
|
|
suite.SetupTest() // reset
|
|
//nolint
|
|
tc.malleate()
|
|
|
|
bz, err := suite.querier(suite.ctx, tc.path, abci.RequestQuery{})
|
|
|
|
//nolint
|
|
if tc.expPass {
|
|
//nolint
|
|
suite.Require().NoError(err, "valid test %d failed: %s", i, tc.msg)
|
|
suite.Require().NotZero(len(bz))
|
|
} else {
|
|
//nolint
|
|
suite.Require().Error(err, "invalid test %d passed: %s", i, tc.msg)
|
|
}
|
|
})
|
|
}
|
|
}
|