cosmos-sdk/x/auth/account_test.go

109 lines
2.6 KiB
Go
Raw Normal View History

2018-05-23 22:09:01 -07:00
package auth
import (
"testing"
"github.com/stretchr/testify/require"
2018-03-02 01:24:07 -08:00
"github.com/tendermint/tendermint/crypto"
"github.com/tendermint/tendermint/crypto/ed25519"
2018-03-02 01:24:07 -08:00
codec "github.com/cosmos/cosmos-sdk/codec"
2018-03-02 01:24:07 -08:00
sdk "github.com/cosmos/cosmos-sdk/types"
)
2018-07-06 00:06:53 -07:00
func keyPubAddr() (crypto.PrivKey, crypto.PubKey, sdk.AccAddress) {
key := ed25519.GenPrivKey()
pub := key.PubKey()
2018-07-06 00:06:53 -07:00
addr := sdk.AccAddress(pub.Address())
2018-04-06 17:25:08 -07:00
return key, pub, addr
2018-03-17 13:20:24 -07:00
}
func TestBaseAddressPubKey(t *testing.T) {
2018-03-17 13:20:24 -07:00
_, pub1, addr1 := keyPubAddr()
_, pub2, addr2 := keyPubAddr()
acc := NewBaseAccountWithAddress(addr1)
2018-03-17 13:20:24 -07:00
// check the address (set) and pubkey (not set)
require.EqualValues(t, addr1, acc.GetAddress())
require.EqualValues(t, nil, acc.GetPubKey())
2018-01-17 16:42:05 -08:00
2018-03-17 13:53:27 -07:00
// can't override address
2018-03-17 13:20:24 -07:00
err := acc.SetAddress(addr2)
require.NotNil(t, err)
require.EqualValues(t, addr1, acc.GetAddress())
2018-03-17 13:20:24 -07:00
// set the pubkey
err = acc.SetPubKey(pub1)
require.Nil(t, err)
require.Equal(t, pub1, acc.GetPubKey())
2018-05-06 22:13:32 -07:00
// can override pubkey
2018-03-17 13:20:24 -07:00
err = acc.SetPubKey(pub2)
require.Nil(t, err)
require.Equal(t, pub2, acc.GetPubKey())
2018-03-17 13:20:24 -07:00
//------------------------------------
// can set address on empty account
acc2 := BaseAccount{}
err = acc2.SetAddress(addr2)
require.Nil(t, err)
require.EqualValues(t, addr2, acc2.GetAddress())
2018-03-17 13:20:24 -07:00
}
func TestBaseAccountCoins(t *testing.T) {
_, _, addr := keyPubAddr()
acc := NewBaseAccountWithAddress(addr)
2018-07-30 17:09:50 -07:00
someCoins := sdk.Coins{sdk.NewInt64Coin("atom", 123), sdk.NewInt64Coin("eth", 246)}
2018-03-17 13:20:24 -07:00
err := acc.SetCoins(someCoins)
require.Nil(t, err)
require.Equal(t, someCoins, acc.GetCoins())
2018-03-17 13:20:24 -07:00
}
2018-03-17 13:20:24 -07:00
func TestBaseAccountSequence(t *testing.T) {
_, _, addr := keyPubAddr()
acc := NewBaseAccountWithAddress(addr)
seq := int64(7)
err := acc.SetSequence(seq)
require.Nil(t, err)
require.Equal(t, seq, acc.GetSequence())
2018-03-17 13:20:24 -07:00
}
func TestBaseAccountMarshal(t *testing.T) {
_, pub, addr := keyPubAddr()
acc := NewBaseAccountWithAddress(addr)
2018-07-30 17:09:50 -07:00
someCoins := sdk.Coins{sdk.NewInt64Coin("atom", 123), sdk.NewInt64Coin("eth", 246)}
2018-03-17 13:20:24 -07:00
seq := int64(7)
// set everything on the account
err := acc.SetPubKey(pub)
require.Nil(t, err)
2018-03-17 13:20:24 -07:00
err = acc.SetSequence(seq)
require.Nil(t, err)
2018-03-17 13:20:24 -07:00
err = acc.SetCoins(someCoins)
require.Nil(t, err)
2018-03-17 13:20:24 -07:00
// need a codec for marshaling
cdc := codec.New()
codec.RegisterCrypto(cdc)
b, err := cdc.MarshalBinaryLengthPrefixed(acc)
require.Nil(t, err)
2018-03-17 13:20:24 -07:00
acc2 := BaseAccount{}
err = cdc.UnmarshalBinaryLengthPrefixed(b, &acc2)
require.Nil(t, err)
require.Equal(t, acc, acc2)
2018-03-17 13:20:24 -07:00
// error on bad bytes
2018-01-15 17:19:39 -08:00
acc2 = BaseAccount{}
err = cdc.UnmarshalBinaryLengthPrefixed(b[:len(b)/2], &acc2)
require.NotNil(t, err)
2018-03-17 13:20:24 -07:00
}