2019-12-13 19:50:19 +00:00
|
|
|
package types
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"testing"
|
|
|
|
|
2020-07-02 15:19:48 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2019-12-13 19:50:19 +00:00
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
|
|
"github.com/cosmos/cosmos-sdk/x/auth"
|
2020-07-02 15:19:48 +00:00
|
|
|
|
2019-12-13 19:50:19 +00:00
|
|
|
tmamino "github.com/tendermint/tendermint/crypto/encoding/amino"
|
|
|
|
"github.com/tendermint/tendermint/crypto/secp256k1"
|
|
|
|
|
|
|
|
emintcrypto "github.com/cosmos/ethermint/crypto"
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
tmamino.RegisterKeyType(emintcrypto.PubKeySecp256k1{}, emintcrypto.PubKeyAminoName)
|
|
|
|
tmamino.RegisterKeyType(emintcrypto.PrivKeySecp256k1{}, emintcrypto.PrivKeyAminoName)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestEthermintAccountJSON(t *testing.T) {
|
|
|
|
pubkey := secp256k1.GenPrivKey().PubKey()
|
|
|
|
addr := sdk.AccAddress(pubkey.Address())
|
2020-08-23 21:41:54 +00:00
|
|
|
balance := sdk.NewCoins(sdk.NewCoin(DenomDefault, sdk.OneInt()))
|
|
|
|
baseAcc := auth.NewBaseAccount(addr, balance, pubkey, 10, 50)
|
2020-04-22 19:26:01 +00:00
|
|
|
ethAcc := EthAccount{BaseAccount: baseAcc, CodeHash: []byte{1, 2}}
|
2019-12-13 19:50:19 +00:00
|
|
|
|
|
|
|
bz, err := json.Marshal(ethAcc)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
bz1, err := ethAcc.MarshalJSON()
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, string(bz1), string(bz))
|
|
|
|
|
2020-04-22 19:26:01 +00:00
|
|
|
var a EthAccount
|
2019-12-13 19:50:19 +00:00
|
|
|
require.NoError(t, json.Unmarshal(bz, &a))
|
|
|
|
require.Equal(t, ethAcc.String(), a.String())
|
|
|
|
require.Equal(t, ethAcc.PubKey, a.PubKey)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestEthermintPubKeyJSON(t *testing.T) {
|
|
|
|
privkey, err := emintcrypto.GenerateKey()
|
|
|
|
require.NoError(t, err)
|
|
|
|
bz := privkey.PubKey().Bytes()
|
|
|
|
|
|
|
|
pubk, err := tmamino.PubKeyFromBytes(bz)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, pubk, privkey.PubKey())
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSecpPubKeyJSON(t *testing.T) {
|
|
|
|
pubkey := secp256k1.GenPrivKey().PubKey()
|
|
|
|
bz := pubkey.Bytes()
|
|
|
|
|
|
|
|
pubk, err := tmamino.PubKeyFromBytes(bz)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, pubk, pubkey)
|
|
|
|
}
|