cosmos-sdk/types/errors_test.go

94 lines
2.5 KiB
Go
Raw Normal View History

2018-03-17 18:03:25 -07:00
package types
import (
"fmt"
2018-03-17 18:03:25 -07:00
"testing"
"github.com/stretchr/testify/require"
2018-03-17 18:03:25 -07:00
)
var codeTypes = []CodeType{
CodeInternal,
CodeTxDecode,
2018-03-17 18:03:25 -07:00
CodeInvalidSequence,
CodeUnauthorized,
CodeInsufficientFunds,
CodeUnknownRequest,
CodeInvalidAddress,
2018-03-17 18:03:25 -07:00
CodeInvalidPubKey,
CodeUnknownAddress,
CodeInsufficientCoins,
CodeInvalidCoins,
CodeOutOfGas,
CodeMemoTooLarge,
2018-03-17 18:03:25 -07:00
}
type errFn func(msg string) Error
var errFns = []errFn{
ErrInternal,
ErrTxDecode,
2018-03-17 18:03:25 -07:00
ErrInvalidSequence,
ErrUnauthorized,
ErrInsufficientFunds,
ErrUnknownRequest,
ErrInvalidAddress,
2018-03-17 18:03:25 -07:00
ErrInvalidPubKey,
ErrUnknownAddress,
ErrInsufficientCoins,
ErrInvalidCoins,
ErrOutOfGas,
ErrMemoTooLarge,
2018-03-17 18:03:25 -07:00
}
func TestCodeType(t *testing.T) {
require.True(t, ABCICodeOK.IsOK())
2018-03-17 18:03:25 -07:00
for tcnum, c := range codeTypes {
2018-03-17 18:03:25 -07:00
msg := CodeToDefaultMsg(c)
require.NotEqual(t, unknownCodeMsg(c), msg, "Code expected to be known. tc #%d, code %d, msg %s", tcnum, c, msg)
2018-03-17 18:03:25 -07:00
}
msg := CodeToDefaultMsg(CodeOK)
require.Equal(t, unknownCodeMsg(CodeOK), msg)
2018-03-17 18:03:25 -07:00
}
func TestErrFn(t *testing.T) {
for i, errFn := range errFns {
err := errFn("")
codeType := codeTypes[i]
require.Equal(t, err.Code(), codeType, "Err function expected to return proper code. tc #%d", i)
2018-08-22 07:15:45 -07:00
require.Equal(t, err.Codespace(), CodespaceRoot, "Err function expected to return proper codespace. tc #%d", i)
require.Equal(t, err.Result().Code, ToABCICode(CodespaceRoot, codeType), "Err function expected to return proper ABCICode. tc #%d")
2018-08-22 07:15:45 -07:00
require.Equal(t, err.QueryResult().Code, uint32(err.ABCICode()), "Err function expected to return proper ABCICode from QueryResult. tc #%d")
require.Equal(t, err.QueryResult().Log, err.ABCILog(), "Err function expected to return proper ABCILog from QueryResult. tc #%d")
2018-03-17 18:03:25 -07:00
}
require.Equal(t, ABCICodeOK, ToABCICode(CodespaceRoot, CodeOK))
2018-03-17 18:03:25 -07:00
}
func TestAppendMsgToErr(t *testing.T) {
for i, errFn := range errFns {
err := errFn("")
errMsg := err.Stacktrace().Error()
abciLog := err.ABCILog()
// plain msg error
msg := AppendMsgToErr("something unexpected happened", errMsg)
require.Equal(t, fmt.Sprintf("something unexpected happened; %s",
errMsg),
msg,
fmt.Sprintf("Should have formatted the error message of ABCI Log. tc #%d", i))
// ABCI Log msg error
msg = AppendMsgToErr("something unexpected happened", abciLog)
msgIdx := mustGetMsgIndex(abciLog)
require.Equal(t, fmt.Sprintf("%s%s; %s}",
abciLog[:msgIdx],
"something unexpected happened",
abciLog[msgIdx:len(abciLog)-1]),
msg,
fmt.Sprintf("Should have formatted the error message of ABCI Log. tc #%d", i))
}
}