Add expiration field to ChainTx

This commit is contained in:
Ethan Frey 2017-07-10 11:44:40 +02:00
parent ad94d060d8
commit af9ce5b553
3 changed files with 57 additions and 7 deletions

View File

@ -13,6 +13,37 @@ import (
"github.com/tendermint/basecoin/state" "github.com/tendermint/basecoin/state"
) )
func TestChainValidate(t *testing.T) {
assert := assert.New(t)
raw := stack.NewRawTx([]byte{1, 2, 3, 4})
cases := []struct {
name string
expires uint64
valid bool
}{
{"hello", 0, true},
{"one-2-three", 123, true},
{"super!@#$%@", 0, false},
{"WISH_2_be", 14, true},
{"öhhh", 54, false},
}
for _, tc := range cases {
tx := NewChainTx(tc.name, tc.expires, raw)
err := tx.ValidateBasic()
if tc.valid {
assert.Nil(err, "%s: %+v", tc.name, err)
} else {
assert.NotNil(err, tc.name)
}
}
empty := NewChainTx("okay", 0, basecoin.Tx{})
err := empty.ValidateBasic()
assert.NotNil(err)
}
func TestChain(t *testing.T) { func TestChain(t *testing.T) {
assert := assert.New(t) assert := assert.New(t)
msg := "got it" msg := "got it"
@ -24,8 +55,8 @@ func TestChain(t *testing.T) {
valid bool valid bool
errorMsg string errorMsg string
}{ }{
{NewChainTx(chainID, raw), true, ""}, {NewChainTx(chainID, 0, raw), true, ""},
{NewChainTx("someone-else", raw), false, "someone-else"}, {NewChainTx("someone-else", 0, raw), false, "someone-else"},
{raw, false, "No chain id provided"}, {raw, false, "No chain id provided"},
} }

View File

@ -1,6 +1,11 @@
package base package base
import "github.com/tendermint/basecoin" import (
"regexp"
"github.com/tendermint/basecoin"
"github.com/tendermint/basecoin/errors"
)
// nolint // nolint
const ( const (
@ -51,20 +56,34 @@ func (mt MultiTx) ValidateBasic() error {
// ChainTx locks this tx to one chainTx, wrap with this before signing // ChainTx locks this tx to one chainTx, wrap with this before signing
type ChainTx struct { type ChainTx struct {
Tx basecoin.Tx `json:"tx"` ChainID string `json:"chain_id"` // name of chain, must be [A-Za-z0-9_-]+
ChainID string `json:"chain_id"` ExpiresAt uint64 `json:"expires_at"` // block height at which it is no longer valid
Tx basecoin.Tx `json:"tx"`
} }
var _ basecoin.TxInner = &ChainTx{} var _ basecoin.TxInner = &ChainTx{}
var (
chainPattern = regexp.MustCompile("^[A-Za-z0-9_-]+$")
)
//nolint - TxInner Functions //nolint - TxInner Functions
func NewChainTx(chainID string, tx basecoin.Tx) basecoin.Tx { func NewChainTx(chainID string, expires uint64, tx basecoin.Tx) basecoin.Tx {
return (ChainTx{Tx: tx, ChainID: chainID}).Wrap() return (ChainTx{Tx: tx, ChainID: chainID}).Wrap()
} }
func (c ChainTx) Wrap() basecoin.Tx { func (c ChainTx) Wrap() basecoin.Tx {
return basecoin.Tx{c} return basecoin.Tx{c}
} }
func (c ChainTx) ValidateBasic() error { func (c ChainTx) ValidateBasic() error {
if c.ChainID == "" {
return errors.ErrNoChain()
}
if !chainPattern.MatchString(c.ChainID) {
return errors.ErrWrongChain(c.ChainID)
}
if c.Tx.Empty() {
return errors.ErrUnknownTxType(c.Tx)
}
// TODO: more checks? chainID? // TODO: more checks? chainID?
return c.Tx.ValidateBasic() return c.Tx.ValidateBasic()
} }

View File

@ -25,7 +25,7 @@ func TestEncoding(t *testing.T) {
}{ }{
{raw}, {raw},
{NewMultiTx(raw, raw2)}, {NewMultiTx(raw, raw2)},
{NewChainTx("foobar", raw)}, {NewChainTx("foobar", 0, raw)},
} }
for idx, tc := range cases { for idx, tc := range cases {