2020-03-04 09:49:59 -08:00
|
|
|
package types_test
|
2018-08-06 12:00:49 -07:00
|
|
|
|
|
|
|
import (
|
2020-03-04 09:49:59 -08:00
|
|
|
"encoding/hex"
|
|
|
|
"strings"
|
2018-08-06 12:00:49 -07:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
2020-03-04 09:49:59 -08:00
|
|
|
abci "github.com/tendermint/tendermint/abci/types"
|
|
|
|
"github.com/tendermint/tendermint/libs/bytes"
|
|
|
|
ctypes "github.com/tendermint/tendermint/rpc/core/types"
|
2020-01-16 13:46:51 -08:00
|
|
|
|
2020-07-17 10:17:21 -07:00
|
|
|
"github.com/cosmos/cosmos-sdk/codec"
|
|
|
|
"github.com/cosmos/cosmos-sdk/codec/types"
|
2020-03-04 09:49:59 -08:00
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
2018-08-06 12:00:49 -07:00
|
|
|
)
|
|
|
|
|
2019-02-22 03:54:31 -08:00
|
|
|
func TestParseABCILog(t *testing.T) {
|
2020-03-04 09:49:59 -08:00
|
|
|
t.Parallel()
|
2019-02-22 03:54:31 -08:00
|
|
|
logs := `[{"log":"","msg_index":1,"success":true}]`
|
|
|
|
|
2020-03-04 09:49:59 -08:00
|
|
|
res, err := sdk.ParseABCILogs(logs)
|
2019-02-22 03:54:31 -08:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Len(t, res, 1)
|
|
|
|
require.Equal(t, res[0].Log, "")
|
2020-07-17 10:17:21 -07:00
|
|
|
require.Equal(t, res[0].MsgIndex, uint32(1))
|
2019-02-22 03:54:31 -08:00
|
|
|
}
|
2019-09-12 08:05:27 -07:00
|
|
|
|
|
|
|
func TestABCIMessageLog(t *testing.T) {
|
2020-03-04 09:49:59 -08:00
|
|
|
t.Parallel()
|
2020-07-17 10:17:21 -07:00
|
|
|
cdc := codec.New()
|
2020-03-04 09:49:59 -08:00
|
|
|
events := sdk.Events{sdk.NewEvent("transfer", sdk.NewAttribute("sender", "foo"))}
|
|
|
|
msgLog := sdk.NewABCIMessageLog(0, "", events)
|
2019-09-12 08:05:27 -07:00
|
|
|
|
2020-03-04 09:49:59 -08:00
|
|
|
msgLogs := sdk.ABCIMessageLogs{msgLog}
|
2020-07-17 10:17:21 -07:00
|
|
|
bz, err := cdc.MarshalJSON(msgLogs)
|
2019-09-12 08:05:27 -07:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, string(bz), msgLogs.String())
|
|
|
|
}
|
2020-03-04 09:49:59 -08:00
|
|
|
|
|
|
|
func TestNewSearchTxsResult(t *testing.T) {
|
|
|
|
t.Parallel()
|
2020-07-17 10:17:21 -07:00
|
|
|
got := sdk.NewSearchTxsResult(150, 20, 2, 20, []*sdk.TxResponse{})
|
2020-03-04 09:49:59 -08:00
|
|
|
require.Equal(t, sdk.SearchTxsResult{
|
|
|
|
TotalCount: 150,
|
|
|
|
Count: 20,
|
|
|
|
PageNumber: 2,
|
|
|
|
PageTotal: 8,
|
|
|
|
Limit: 20,
|
2020-07-17 10:17:21 -07:00
|
|
|
Txs: []*sdk.TxResponse{},
|
2020-03-04 09:49:59 -08:00
|
|
|
}, got)
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
Codespace: res.TxResult.Codespace,
|
|
|
|
Code: res.TxResult.Code,
|
|
|
|
Data: strings.ToUpper(hex.EncodeToString(res.TxResult.Data)),
|
|
|
|
RawLog: res.TxResult.Log,
|
|
|
|
Logs: parsedLogs,
|
|
|
|
Info: res.TxResult.Info,
|
|
|
|
GasWanted: res.TxResult.GasWanted,
|
|
|
|
GasUsed: res.TxResult.GasUsed,
|
|
|
|
Tx: tx,
|
|
|
|
Timestamp: timestamp,
|
|
|
|
*/
|
|
|
|
|
|
|
|
func TestResponseResultTx(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
deliverTxResult := abci.ResponseDeliverTx{
|
|
|
|
Codespace: "codespace",
|
|
|
|
Code: 1,
|
|
|
|
Data: []byte("data"),
|
|
|
|
Log: `[]`,
|
|
|
|
Info: "info",
|
|
|
|
GasWanted: 100,
|
|
|
|
GasUsed: 90,
|
|
|
|
}
|
|
|
|
resultTx := &ctypes.ResultTx{
|
|
|
|
Hash: bytes.HexBytes([]byte("test")),
|
|
|
|
Height: 10,
|
|
|
|
TxResult: deliverTxResult,
|
|
|
|
}
|
|
|
|
logs, err := sdk.ParseABCILogs(`[]`)
|
|
|
|
require.NoError(t, err)
|
2020-07-17 10:17:21 -07:00
|
|
|
want := &sdk.TxResponse{
|
2020-03-04 09:49:59 -08:00
|
|
|
TxHash: "74657374",
|
|
|
|
Height: 10,
|
|
|
|
Codespace: "codespace",
|
|
|
|
Code: 1,
|
|
|
|
Data: strings.ToUpper(hex.EncodeToString([]byte("data"))),
|
|
|
|
RawLog: `[]`,
|
|
|
|
Logs: logs,
|
|
|
|
Info: "info",
|
|
|
|
GasWanted: 100,
|
|
|
|
GasUsed: 90,
|
2020-07-17 10:17:21 -07:00
|
|
|
Tx: &types.Any{},
|
2020-03-04 09:49:59 -08:00
|
|
|
Timestamp: "timestamp",
|
|
|
|
}
|
|
|
|
|
|
|
|
require.Equal(t, want, sdk.NewResponseResultTx(resultTx, sdk.Tx(nil), "timestamp"))
|
2020-07-17 10:17:21 -07:00
|
|
|
require.Equal(t, (*sdk.TxResponse)(nil), sdk.NewResponseResultTx(nil, sdk.Tx(nil), "timestamp"))
|
2020-03-04 09:49:59 -08:00
|
|
|
require.Equal(t, `Response:
|
|
|
|
Height: 10
|
|
|
|
TxHash: 74657374
|
|
|
|
Code: 1
|
|
|
|
Data: 64617461
|
|
|
|
Raw Log: []
|
|
|
|
Logs: []
|
|
|
|
Info: info
|
|
|
|
GasWanted: 100
|
|
|
|
GasUsed: 90
|
|
|
|
Codespace: codespace
|
|
|
|
Timestamp: timestamp`, sdk.NewResponseResultTx(resultTx, sdk.Tx(nil), "timestamp").String())
|
|
|
|
require.True(t, sdk.TxResponse{}.Empty())
|
|
|
|
require.False(t, want.Empty())
|
|
|
|
|
|
|
|
resultBroadcastTx := &ctypes.ResultBroadcastTx{
|
2020-05-12 08:26:54 -07:00
|
|
|
Code: 1,
|
|
|
|
Codespace: "codespace",
|
|
|
|
Data: []byte("data"),
|
|
|
|
Log: `[]`,
|
|
|
|
Hash: bytes.HexBytes([]byte("test")),
|
2020-03-04 09:49:59 -08:00
|
|
|
}
|
2020-07-17 10:17:21 -07:00
|
|
|
require.Equal(t, &sdk.TxResponse{
|
2020-05-12 08:26:54 -07:00
|
|
|
Code: 1,
|
|
|
|
Codespace: "codespace",
|
|
|
|
Data: "64617461",
|
|
|
|
RawLog: `[]`,
|
|
|
|
Logs: logs,
|
|
|
|
TxHash: "74657374",
|
2020-03-04 09:49:59 -08:00
|
|
|
}, sdk.NewResponseFormatBroadcastTx(resultBroadcastTx))
|
2020-07-17 10:17:21 -07:00
|
|
|
|
|
|
|
require.Equal(t, (*sdk.TxResponse)(nil), sdk.NewResponseFormatBroadcastTx(nil))
|
2020-03-04 09:49:59 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestResponseFormatBroadcastTxCommit(t *testing.T) {
|
|
|
|
// test nil
|
2020-07-17 10:17:21 -07:00
|
|
|
require.Equal(t, (*sdk.TxResponse)(nil), sdk.NewResponseFormatBroadcastTxCommit(nil))
|
2020-03-04 09:49:59 -08:00
|
|
|
|
|
|
|
logs, err := sdk.ParseABCILogs(`[]`)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// test checkTx
|
|
|
|
checkTxResult := &ctypes.ResultBroadcastTxCommit{
|
|
|
|
Height: 10,
|
|
|
|
Hash: bytes.HexBytes([]byte("test")),
|
|
|
|
CheckTx: abci.ResponseCheckTx{
|
|
|
|
Code: 90,
|
|
|
|
Data: nil,
|
|
|
|
Log: `[]`,
|
|
|
|
Info: "info",
|
|
|
|
GasWanted: 99,
|
|
|
|
GasUsed: 100,
|
|
|
|
Codespace: "codespace",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
deliverTxResult := &ctypes.ResultBroadcastTxCommit{
|
|
|
|
Height: 10,
|
|
|
|
Hash: bytes.HexBytes([]byte("test")),
|
|
|
|
DeliverTx: abci.ResponseDeliverTx{
|
|
|
|
Code: 90,
|
|
|
|
Data: nil,
|
|
|
|
Log: `[]`,
|
|
|
|
Info: "info",
|
|
|
|
GasWanted: 99,
|
|
|
|
GasUsed: 100,
|
|
|
|
Codespace: "codespace",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2020-07-17 10:17:21 -07:00
|
|
|
want := &sdk.TxResponse{
|
2020-03-04 09:49:59 -08:00
|
|
|
Height: 10,
|
|
|
|
TxHash: "74657374",
|
|
|
|
Codespace: "codespace",
|
|
|
|
Code: 90,
|
|
|
|
Data: "",
|
|
|
|
RawLog: `[]`,
|
|
|
|
Logs: logs,
|
|
|
|
Info: "info",
|
|
|
|
GasWanted: 99,
|
|
|
|
GasUsed: 100,
|
|
|
|
}
|
|
|
|
require.Equal(t, want, sdk.NewResponseFormatBroadcastTxCommit(checkTxResult))
|
|
|
|
require.Equal(t, want, sdk.NewResponseFormatBroadcastTxCommit(deliverTxResult))
|
|
|
|
}
|