From 19ef418113059af0c50056f7680af704a25a4421 Mon Sep 17 00:00:00 2001 From: louisliu2048 Date: Mon, 27 Sep 2021 18:35:32 +0800 Subject: [PATCH] add estimate gas process to get tx's real gas wanted --- client/context/broadcast.go | 49 +++++++++++++++++++++++++------- client/context/broadcast_test.go | 2 +- x/auth/client/cli/broadcast.go | 2 +- x/auth/client/rest/broadcast.go | 2 +- x/auth/client/utils/tx.go | 2 +- 5 files changed, 43 insertions(+), 14 deletions(-) diff --git a/client/context/broadcast.go b/client/context/broadcast.go index 67251b6da89d..3ff1bd0843e5 100644 --- a/client/context/broadcast.go +++ b/client/context/broadcast.go @@ -3,9 +3,11 @@ package context import ( "fmt" "strings" + "encoding/json" "github.com/tendermint/tendermint/crypto/tmhash" "github.com/tendermint/tendermint/mempool" + "github.com/tendermint/tendermint/rpc/core" "github.com/cosmos/cosmos-sdk/client/flags" sdk "github.com/cosmos/cosmos-sdk/types" @@ -16,16 +18,16 @@ import ( // based on the context parameters. The result of the broadcast is parsed into // an intermediate structure which is logged if the context has a logger // defined. -func (ctx CLIContext) BroadcastTx(txBytes []byte) (res sdk.TxResponse, err error) { +func (ctx CLIContext) BroadcastTx(txBytes []byte, estGasUse uint64) (res sdk.TxResponse, err error) { switch ctx.BroadcastMode { case flags.BroadcastSync: - res, err = ctx.BroadcastTxSync(txBytes) + res, err = ctx.BroadcastTxSync(txBytes, estGasUse) case flags.BroadcastAsync: - res, err = ctx.BroadcastTxAsync(txBytes) + res, err = ctx.BroadcastTxAsync(txBytes, estGasUse) case flags.BroadcastBlock: - res, err = ctx.BroadcastTxCommit(txBytes) + res, err = ctx.BroadcastTxCommit(txBytes, estGasUse) default: return sdk.TxResponse{}, fmt.Errorf("unsupported return type %s; supported types: sync, async, block", ctx.BroadcastMode) @@ -81,13 +83,22 @@ func CheckTendermintError(err error, txBytes []byte) *sdk.TxResponse { // NOTE: This should ideally not be used as the request may timeout but the tx // may still be included in a block. Use BroadcastTxAsync or BroadcastTxSync // instead. -func (ctx CLIContext) BroadcastTxCommit(txBytes []byte) (sdk.TxResponse, error) { +func (ctx CLIContext) BroadcastTxCommit(txBytes []byte, estGasUse uint64) (sdk.TxResponse, error) { node, err := ctx.GetNode() if err != nil { return sdk.TxResponse{}, err } - res, err := node.BroadcastTxCommit(txBytes) + wMsg := core.WrapEthMsg { + RawTxData: txBytes, + EstimatedGasUse: estGasUse, + } + wTxBytes, err := json.Marshal(wMsg) + if err != nil { + return sdk.TxResponse{}, err + } + + res, err := node.BroadcastTxCommit(wTxBytes) if err != nil { if errRes := CheckTendermintError(err, txBytes); errRes != nil { return *errRes, nil @@ -109,13 +120,22 @@ func (ctx CLIContext) BroadcastTxCommit(txBytes []byte) (sdk.TxResponse, error) // BroadcastTxSync broadcasts transaction bytes to a Tendermint node // synchronously (i.e. returns after CheckTx execution). -func (ctx CLIContext) BroadcastTxSync(txBytes []byte) (sdk.TxResponse, error) { +func (ctx CLIContext) BroadcastTxSync(txBytes []byte, estGasUse uint64) (sdk.TxResponse, error) { node, err := ctx.GetNode() if err != nil { return sdk.TxResponse{}, err } - res, err := node.BroadcastTxSync(txBytes) + wMsg := core.WrapEthMsg { + RawTxData: txBytes, + EstimatedGasUse: estGasUse, + } + wTxBytes, err := json.Marshal(wMsg) + if err != nil { + return sdk.TxResponse{}, err + } + + res, err := node.BroadcastTxSync(wTxBytes) if errRes := CheckTendermintError(err, txBytes); errRes != nil { return *errRes, nil } @@ -125,13 +145,22 @@ func (ctx CLIContext) BroadcastTxSync(txBytes []byte) (sdk.TxResponse, error) { // BroadcastTxAsync broadcasts transaction bytes to a Tendermint node // asynchronously (i.e. returns immediately). -func (ctx CLIContext) BroadcastTxAsync(txBytes []byte) (sdk.TxResponse, error) { +func (ctx CLIContext) BroadcastTxAsync(txBytes []byte, estGasUse uint64) (sdk.TxResponse, error) { node, err := ctx.GetNode() if err != nil { return sdk.TxResponse{}, err } - res, err := node.BroadcastTxAsync(txBytes) + wMsg := core.WrapEthMsg { + RawTxData: txBytes, + EstimatedGasUse: estGasUse, + } + wTxBytes, err := json.Marshal(wMsg) + if err != nil { + return sdk.TxResponse{}, err + } + + res, err := node.BroadcastTxAsync(wTxBytes) if errRes := CheckTendermintError(err, txBytes); errRes != nil { return *errRes, nil } diff --git a/client/context/broadcast_test.go b/client/context/broadcast_test.go index 530645b9d187..a56a434418dc 100644 --- a/client/context/broadcast_test.go +++ b/client/context/broadcast_test.go @@ -59,7 +59,7 @@ func TestBroadcastError(t *testing.T) { for _, mode := range modes { for err, code := range errors { ctx := CreateContextWithErrorAndMode(err, mode) - resp, returnedErr := ctx.BroadcastTx(txBytes) + resp, returnedErr := ctx.BroadcastTx(txBytes, 1000) require.NoError(t, returnedErr) require.Equal(t, code, resp.Code) require.Equal(t, txHash, resp.TxHash) diff --git a/x/auth/client/cli/broadcast.go b/x/auth/client/cli/broadcast.go index 37590787b4dd..a8fde9606e42 100644 --- a/x/auth/client/cli/broadcast.go +++ b/x/auth/client/cli/broadcast.go @@ -36,7 +36,7 @@ $ tx broadcast ./mytxn.json return } - res, err := cliCtx.BroadcastTx(txBytes) + res, err := cliCtx.BroadcastTx(txBytes, stdTx.GetGas()) cliCtx.PrintOutput(res) return err diff --git a/x/auth/client/rest/broadcast.go b/x/auth/client/rest/broadcast.go index e7609194c390..7c9f689c7a0f 100644 --- a/x/auth/client/rest/broadcast.go +++ b/x/auth/client/rest/broadcast.go @@ -42,7 +42,7 @@ func BroadcastTxRequest(cliCtx context.CLIContext) http.HandlerFunc { cliCtx = cliCtx.WithBroadcastMode(req.Mode) - res, err := cliCtx.BroadcastTx(txBytes) + res, err := cliCtx.BroadcastTx(txBytes, req.Tx.GetGas()) if err != nil { rest.WriteErrorResponse(w, http.StatusInternalServerError, err.Error()) return diff --git a/x/auth/client/utils/tx.go b/x/auth/client/utils/tx.go index 38189bc4426d..e13cdb4c069e 100644 --- a/x/auth/client/utils/tx.go +++ b/x/auth/client/utils/tx.go @@ -100,7 +100,7 @@ func CompleteAndBroadcastTxCLI(txBldr authtypes.TxBuilder, cliCtx context.CLICon } // broadcast to a Tendermint node - res, err := cliCtx.BroadcastTx(txBytes) + res, err := cliCtx.BroadcastTx(txBytes, txBldr.Gas()) if err != nil { return err }