* WIP on protobuf keys * Use Type() and Bytes() in sr25519 pub key Equals * Add tests * Add few more tests * Update other pub/priv key types Equals * Fix PrivKey's Sign method * Rename variables in tests * Fix infinite recursive calls * Use tm ed25519 keys * Add Sign and VerifySignature tests * Remove ed25519 and sr25519 references * proto linting * Add proto crypto file * Implement some of the new multisig proto type methods * Add tests for MultisigThresholdPubKey * Add tests for pubkey pb/amino conversion functions * Move crypto types.go and register new proto pubkeys * Add missing pointer ref * Address review comments * panic in MultisigThresholdPubKey VerifySignature * Use internal crypto.PubKey in multisig * Add tests for MultisigThresholdPubKey VerifyMultisignature * Only keep LegacyAminoMultisigThresholdPubKey and move to proto keys to v1 * Remove conversion functions and introduce internal PubKey type * Override Amino marshaling for proto pubkeys * Merge master * Make proto-gen * Start removal of old PubKeyMultisigThreshold references * Fix tests * Fix solomachine * Fix ante handler tests * Pull latest go-amino * Remove ed25519 * Remove old secp256k1 PubKey and PrivKey * Uncomment test case * Fix linting issues * More linting * Revert tests keys values * Add Amino overrides to proto keys * Add pubkey test * Fix tests * Use threshold isntead of K * Standardize Type * Revert standardize types commit * Fix build * Fix lint * Fix lint * Add comment * Register crypto.PubKey * Add empty key in BuildSimTx * Simplify proto names * Unpack interfaces for signing desc * Fix IBC tests? * Format proto * Use secp256k1 in ibc * Fixed merge issues * Uncomment tests * Update x/ibc/testing/solomachine.go * UnpackInterfaces for solomachine types * Remove old multisig * Add amino marshal for multisig * Fix lint * Correctly register amino * One test left! * Remove old struct * Fix test * Fix test * Unpack into tmcrypto * Remove old threshold pubkey tests * Fix register amino * Fix lint * Use sdk crypto PubKey in multisig UnpackInterfaces * Potential fix? * Register LegacyAminoPubKey * Register our own PubKey * Register tmcrypto PubKey * Register both PubKeys * Register interfaces in test * Refactor fiels * Add comments * Use anil's suggestion * Add norace back * Check nil * Address comments * FIx lint * Add tests for solomachine unpack interfaces * Fix query tx by hash * Better name in amino register * Display StdTx instead of proto Tx * Remove useless check Co-authored-by: Aaron Craelius <aaronc@users.noreply.github.com> Co-authored-by: blushi <marie.gauthier63@gmail.com> Co-authored-by: Alexander Bezobchuk <alexanderbez@users.noreply.github.com> Co-authored-by: colin axnér <25233464+colin-axner@users.noreply.github.com>
120 lines
3.8 KiB
Go
120 lines
3.8 KiB
Go
package simulate_test
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/suite"
|
|
tmproto "github.com/tendermint/tendermint/proto/tendermint/types"
|
|
|
|
"github.com/cosmos/cosmos-sdk/baseapp"
|
|
"github.com/cosmos/cosmos-sdk/client"
|
|
"github.com/cosmos/cosmos-sdk/client/grpc/simulate"
|
|
"github.com/cosmos/cosmos-sdk/client/tx"
|
|
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
|
|
"github.com/cosmos/cosmos-sdk/simapp"
|
|
"github.com/cosmos/cosmos-sdk/testutil/testdata"
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
txtypes "github.com/cosmos/cosmos-sdk/types/tx"
|
|
"github.com/cosmos/cosmos-sdk/types/tx/signing"
|
|
authsigning "github.com/cosmos/cosmos-sdk/x/auth/signing"
|
|
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
|
|
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
|
|
)
|
|
|
|
type IntegrationTestSuite struct {
|
|
suite.Suite
|
|
|
|
app *simapp.SimApp
|
|
clientCtx client.Context
|
|
queryClient simulate.SimulateServiceClient
|
|
sdkCtx sdk.Context
|
|
}
|
|
|
|
func (s *IntegrationTestSuite) SetupSuite() {
|
|
app := simapp.Setup(true)
|
|
sdkCtx := app.BaseApp.NewContext(true, tmproto.Header{})
|
|
|
|
app.AccountKeeper.SetParams(sdkCtx, authtypes.DefaultParams())
|
|
app.BankKeeper.SetParams(sdkCtx, banktypes.DefaultParams())
|
|
|
|
// Set up TxConfig.
|
|
encodingConfig := simapp.MakeEncodingConfig()
|
|
clientCtx := client.Context{}.WithTxConfig(encodingConfig.TxConfig)
|
|
|
|
// Create new simulation server.
|
|
srv := simulate.NewSimulateServer(app.BaseApp.Simulate, encodingConfig.InterfaceRegistry)
|
|
|
|
queryHelper := baseapp.NewQueryServerTestHelper(sdkCtx, app.InterfaceRegistry())
|
|
simulate.RegisterSimulateServiceServer(queryHelper, srv)
|
|
queryClient := simulate.NewSimulateServiceClient(queryHelper)
|
|
|
|
s.app = app
|
|
s.clientCtx = clientCtx
|
|
s.queryClient = queryClient
|
|
s.sdkCtx = sdkCtx
|
|
}
|
|
|
|
func (s IntegrationTestSuite) TestSimulateService() {
|
|
// Create an account with some funds.
|
|
priv1, _, addr1 := testdata.KeyTestPubAddr()
|
|
acc1 := s.app.AccountKeeper.NewAccountWithAddress(s.sdkCtx, addr1)
|
|
err := acc1.SetAccountNumber(0)
|
|
s.Require().NoError(err)
|
|
s.app.AccountKeeper.SetAccount(s.sdkCtx, acc1)
|
|
s.app.BankKeeper.SetBalances(s.sdkCtx, addr1, sdk.Coins{
|
|
sdk.NewInt64Coin("atom", 10000000),
|
|
})
|
|
|
|
// Create a test x/bank MsgSend.
|
|
coins := sdk.NewCoins(sdk.NewInt64Coin("atom", 10))
|
|
_, _, addr2 := testdata.KeyTestPubAddr()
|
|
msg := banktypes.NewMsgSend(addr1, addr2, coins)
|
|
feeAmount := testdata.NewTestFeeAmount()
|
|
gasLimit := testdata.NewTestGasLimit()
|
|
memo := "foo"
|
|
accSeq, accNum := uint64(0), uint64(0)
|
|
|
|
// Create a txBuilder.
|
|
txBuilder := s.clientCtx.TxConfig.NewTxBuilder()
|
|
txBuilder.SetMsgs(msg)
|
|
txBuilder.SetMemo(memo)
|
|
txBuilder.SetFeeAmount(feeAmount)
|
|
txBuilder.SetGasLimit(gasLimit)
|
|
// 1st round: set empty signature
|
|
sigV2 := signing.SignatureV2{
|
|
PubKey: priv1.PubKey(),
|
|
Data: &signing.SingleSignatureData{
|
|
SignMode: s.clientCtx.TxConfig.SignModeHandler().DefaultMode(),
|
|
Signature: nil,
|
|
},
|
|
}
|
|
txBuilder.SetSignatures(sigV2)
|
|
// 2nd round: actually sign
|
|
sigV2, err = tx.SignWithPrivKey(
|
|
s.clientCtx.TxConfig.SignModeHandler().DefaultMode(),
|
|
authsigning.SignerData{ChainID: s.sdkCtx.ChainID(), AccountNumber: accNum, Sequence: accSeq},
|
|
txBuilder, priv1, s.clientCtx.TxConfig, accSeq,
|
|
)
|
|
txBuilder.SetSignatures(sigV2)
|
|
|
|
any, ok := txBuilder.(codectypes.IntoAny)
|
|
s.Require().True(ok)
|
|
cached := any.AsAny().GetCachedValue()
|
|
txTx, ok := cached.(*txtypes.Tx)
|
|
s.Require().True(ok)
|
|
res, err := s.queryClient.Simulate(
|
|
context.Background(),
|
|
&simulate.SimulateRequest{Tx: txTx},
|
|
)
|
|
s.Require().NoError(err)
|
|
|
|
// Check the result and gas used are correct.
|
|
s.Require().Equal(len(res.GetResult().GetEvents()), 4) // 1 transfer, 3 messages.
|
|
s.Require().True(res.GetGasInfo().GetGasUsed() > 0) // Gas used sometimes change, just check it's not empty.
|
|
}
|
|
|
|
func TestSimulateTestSuite(t *testing.T) {
|
|
suite.Run(t, new(IntegrationTestSuite))
|
|
}
|