cosmos-sdk/client/lcd/lcd_test.go

596 lines
18 KiB
Go
Raw Normal View History

2018-03-05 08:41:50 -08:00
package lcd
import (
"encoding/hex"
2018-03-05 08:41:50 -08:00
"encoding/json"
2018-03-10 10:54:14 -08:00
"fmt"
2018-03-05 08:41:50 -08:00
"net/http"
2018-03-10 09:31:52 -08:00
"regexp"
2018-03-05 08:41:50 -08:00
"testing"
2018-03-09 02:03:15 -08:00
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
2018-03-17 17:42:18 -07:00
abci "github.com/tendermint/abci/types"
cryptoKeys "github.com/tendermint/go-crypto/keys"
p2p "github.com/tendermint/tendermint/p2p"
ctypes "github.com/tendermint/tendermint/rpc/core/types"
client "github.com/cosmos/cosmos-sdk/client"
keys "github.com/cosmos/cosmos-sdk/client/keys"
rpc "github.com/cosmos/cosmos-sdk/client/rpc"
tests "github.com/cosmos/cosmos-sdk/tests"
2018-03-17 17:42:18 -07:00
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/cosmos-sdk/x/auth"
2018-05-14 17:43:46 -07:00
"github.com/cosmos/cosmos-sdk/x/stake"
stakerest "github.com/cosmos/cosmos-sdk/x/stake/client/rest"
2018-03-17 17:42:18 -07:00
)
2018-03-05 08:41:50 -08:00
func TestKeys(t *testing.T) {
name, password := "test", "1234567890"
addr, seed := CreateAddr(t, "test", password, GetKB(t))
cleanup, _, port := InitializeTestLCD(t, 2, []sdk.Address{addr})
defer cleanup()
2018-03-05 08:41:50 -08:00
2018-03-10 09:31:52 -08:00
// get seed
res, body := Request(t, port, "GET", "/keys/seed", nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-17 17:42:18 -07:00
newSeed := body
2018-03-10 09:31:52 -08:00
reg, err := regexp.Compile(`([a-z]+ ){12}`)
require.Nil(t, err)
match := reg.MatchString(seed)
assert.True(t, match, "Returned seed has wrong format", seed)
2018-03-10 09:31:52 -08:00
2018-03-17 17:42:18 -07:00
newName := "test_newname"
newPassword := "0987654321"
2018-03-10 08:15:56 -08:00
// add key
2018-03-17 17:42:18 -07:00
var jsonStr = []byte(fmt.Sprintf(`{"name":"test_fail", "password":"%s"}`, password))
res, body = Request(t, port, "POST", "/keys", jsonStr)
2018-03-10 09:31:52 -08:00
assert.Equal(t, http.StatusBadRequest, res.StatusCode, "Account creation should require a seed")
2018-03-10 09:31:52 -08:00
2018-03-17 17:42:18 -07:00
jsonStr = []byte(fmt.Sprintf(`{"name":"%s", "password":"%s", "seed": "%s"}`, newName, newPassword, newSeed))
res, body = Request(t, port, "POST", "/keys", jsonStr)
2018-03-10 09:31:52 -08:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
addr2 := body
assert.Len(t, addr2, 40, "Returned address has wrong format", addr2)
2018-03-05 08:41:50 -08:00
// existing keys
res, body = Request(t, port, "GET", "/keys", nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-17 17:42:18 -07:00
var m [2]keys.KeyOutput
2018-04-07 10:56:49 -07:00
err = cdc.UnmarshalJSON([]byte(body), &m)
2018-03-12 08:31:27 -07:00
require.Nil(t, err)
2018-03-05 08:41:50 -08:00
addr2Acc, err := sdk.GetAccAddressHex(addr2)
require.Nil(t, err)
addr2Bech32 := sdk.MustBech32ifyAcc(addr2Acc)
addrBech32 := sdk.MustBech32ifyAcc(addr)
assert.Equal(t, name, m[0].Name, "Did not serve keys name correctly")
assert.Equal(t, addrBech32, m[0].Address, "Did not serve keys Address correctly")
assert.Equal(t, newName, m[1].Name, "Did not serve keys name correctly")
assert.Equal(t, addr2Bech32, m[1].Address, "Did not serve keys Address correctly")
2018-03-05 08:41:50 -08:00
// select key
2018-03-17 17:42:18 -07:00
keyEndpoint := fmt.Sprintf("/keys/%s", newName)
res, body = Request(t, port, "GET", keyEndpoint, nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-05 08:41:50 -08:00
var m2 keys.KeyOutput
2018-04-07 10:56:49 -07:00
err = cdc.UnmarshalJSON([]byte(body), &m2)
require.Nil(t, err)
2018-03-05 08:41:50 -08:00
2018-03-17 17:42:18 -07:00
assert.Equal(t, newName, m2.Name, "Did not serve keys name correctly")
assert.Equal(t, addr2Bech32, m2.Address, "Did not serve keys Address correctly")
2018-03-05 08:41:50 -08:00
// update key
jsonStr = []byte(fmt.Sprintf(`{
"old_password":"%s",
"new_password":"12345678901"
}`, newPassword))
res, body = Request(t, port, "PUT", keyEndpoint, jsonStr)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-05 08:41:50 -08:00
// here it should say unauthorized as we changed the password before
res, body = Request(t, port, "PUT", keyEndpoint, jsonStr)
require.Equal(t, http.StatusUnauthorized, res.StatusCode, body)
2018-03-05 08:41:50 -08:00
// delete key
jsonStr = []byte(`{"password":"12345678901"}`)
res, body = Request(t, port, "DELETE", keyEndpoint, jsonStr)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-12 07:47:26 -07:00
}
2018-03-05 08:41:50 -08:00
2018-03-09 02:54:19 -08:00
func TestVersion(t *testing.T) {
cleanup, _, port := InitializeTestLCD(t, 1, []sdk.Address{})
defer cleanup()
2018-03-09 02:54:19 -08:00
// node info
res, body := Request(t, port, "GET", "/version", nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-09 02:54:19 -08:00
2018-03-10 09:36:15 -08:00
reg, err := regexp.Compile(`\d+\.\d+\.\d+(-dev)?`)
require.Nil(t, err)
match := reg.MatchString(body)
assert.True(t, match, body)
// node info
res, body = Request(t, port, "GET", "/node_version", nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
reg, err = regexp.Compile(`\d+\.\d+\.\d+(-dev)?`)
require.Nil(t, err)
match = reg.MatchString(body)
assert.True(t, match, body)
2018-03-09 02:54:19 -08:00
}
2018-03-09 02:03:15 -08:00
func TestNodeStatus(t *testing.T) {
cleanup, _, port := InitializeTestLCD(t, 1, []sdk.Address{})
defer cleanup()
2018-03-08 06:50:12 -08:00
2018-03-09 02:03:15 -08:00
// node info
res, body := Request(t, port, "GET", "/node_info", nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-08 06:50:12 -08:00
var nodeInfo p2p.NodeInfo
2018-04-07 10:56:49 -07:00
err := cdc.UnmarshalJSON([]byte(body), &nodeInfo)
2018-03-08 07:06:40 -08:00
require.Nil(t, err, "Couldn't parse node info")
2018-03-08 06:50:12 -08:00
assert.NotEqual(t, p2p.NodeInfo{}, nodeInfo, "res: %v", res)
2018-03-09 02:03:15 -08:00
// syncing
res, body = Request(t, port, "GET", "/syncing", nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-09 02:03:15 -08:00
// we expect that there is no other node running so the syncing state is "false"
assert.Equal(t, "false", body)
}
2018-03-09 02:03:15 -08:00
func TestBlock(t *testing.T) {
cleanup, _, port := InitializeTestLCD(t, 1, []sdk.Address{})
defer cleanup()
2018-03-14 03:43:31 -07:00
2018-03-13 08:42:29 -07:00
var resultBlock ctypes.ResultBlock
res, body := Request(t, port, "GET", "/blocks/latest", nil)
2018-03-13 08:42:29 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-04-07 10:56:49 -07:00
err := cdc.UnmarshalJSON([]byte(body), &resultBlock)
2018-03-13 08:42:29 -07:00
require.Nil(t, err, "Couldn't parse block")
2018-03-13 08:42:29 -07:00
assert.NotEqual(t, ctypes.ResultBlock{}, resultBlock)
2018-03-10 08:35:21 -08:00
// --
res, body = Request(t, port, "GET", "/blocks/1", nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-13 08:42:29 -07:00
err = json.Unmarshal([]byte(body), &resultBlock)
2018-03-10 11:14:13 -08:00
require.Nil(t, err, "Couldn't parse block")
assert.NotEqual(t, ctypes.ResultBlock{}, resultBlock)
2018-03-10 08:35:21 -08:00
// --
res, body = Request(t, port, "GET", "/blocks/1000000000", nil)
require.Equal(t, http.StatusNotFound, res.StatusCode, body)
}
func TestValidators(t *testing.T) {
cleanup, _, port := InitializeTestLCD(t, 1, []sdk.Address{})
defer cleanup()
2018-03-14 03:43:31 -07:00
var resultVals rpc.ResultValidatorsOutput
2018-03-13 08:42:29 -07:00
res, body := Request(t, port, "GET", "/validatorsets/latest", nil)
2018-03-13 08:42:29 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-04-07 10:56:49 -07:00
err := cdc.UnmarshalJSON([]byte(body), &resultVals)
2018-03-13 08:42:29 -07:00
require.Nil(t, err, "Couldn't parse validatorset")
assert.NotEqual(t, rpc.ResultValidatorsOutput{}, resultVals)
assert.Contains(t, resultVals.Validators[0].Address, "cosmosvaladdr")
assert.Contains(t, resultVals.Validators[0].PubKey, "cosmosvalpub")
2018-03-10 08:35:21 -08:00
// --
res, body = Request(t, port, "GET", "/validatorsets/1", nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-04-07 10:56:49 -07:00
err = cdc.UnmarshalJSON([]byte(body), &resultVals)
2018-03-10 11:14:13 -08:00
require.Nil(t, err, "Couldn't parse validatorset")
assert.NotEqual(t, rpc.ResultValidatorsOutput{}, resultVals)
2018-03-10 08:35:21 -08:00
// --
res, body = Request(t, port, "GET", "/validatorsets/1000000000", nil)
require.Equal(t, http.StatusNotFound, res.StatusCode)
2018-03-08 06:50:12 -08:00
}
2018-03-10 09:33:05 -08:00
func TestCoinSend(t *testing.T) {
name, password := "test", "1234567890"
addr, seed := CreateAddr(t, "test", password, GetKB(t))
cleanup, _, port := InitializeTestLCD(t, 2, []sdk.Address{addr})
defer cleanup()
bz, err := hex.DecodeString("8FA6AB57AD6870F6B5B2E57735F38F2F30E73CB6")
require.NoError(t, err)
someFakeAddr := sdk.MustBech32ifyAcc(bz)
2018-03-10 10:54:14 -08:00
2018-03-10 09:33:05 -08:00
// query empty
res, body := Request(t, port, "GET", "/accounts/"+someFakeAddr, nil)
require.Equal(t, http.StatusNoContent, res.StatusCode, body)
2018-03-10 09:33:05 -08:00
acc := getAccount(t, port, addr)
2018-04-07 10:56:49 -07:00
initialBalance := acc.GetCoins()
2018-03-14 05:01:55 -07:00
// create TX
receiveAddr, resultTx := doSend(t, port, seed, name, password, addr)
tests.WaitForHeight(resultTx.Height+1, port)
2018-03-14 08:18:47 -07:00
// check if tx was commited
assert.Equal(t, uint32(0), resultTx.CheckTx.Code)
assert.Equal(t, uint32(0), resultTx.DeliverTx.Code)
2018-03-14 03:43:31 -07:00
2018-03-14 05:01:55 -07:00
// query sender
acc = getAccount(t, port, addr)
2018-04-07 10:56:49 -07:00
coins := acc.GetCoins()
2018-03-14 08:18:47 -07:00
mycoins := coins[0]
assert.Equal(t, "steak", mycoins.Denom)
assert.Equal(t, initialBalance[0].Amount.SubRaw(1), mycoins.Amount)
2018-03-10 09:33:05 -08:00
2018-03-14 05:01:55 -07:00
// query receiver
acc = getAccount(t, port, receiveAddr)
2018-04-07 10:56:49 -07:00
coins = acc.GetCoins()
2018-03-14 08:18:47 -07:00
mycoins = coins[0]
assert.Equal(t, "steak", mycoins.Denom)
assert.Equal(t, int64(1), mycoins.Amount.Int64())
2018-03-10 09:33:05 -08:00
}
2018-03-19 10:13:47 -07:00
func TestIBCTransfer(t *testing.T) {
name, password := "test", "1234567890"
addr, seed := CreateAddr(t, "test", password, GetKB(t))
cleanup, _, port := InitializeTestLCD(t, 2, []sdk.Address{addr})
defer cleanup()
2018-03-19 10:13:47 -07:00
acc := getAccount(t, port, addr)
2018-04-07 10:56:49 -07:00
initialBalance := acc.GetCoins()
2018-03-19 10:13:47 -07:00
// create TX
resultTx := doIBCTransfer(t, port, seed, name, password, addr)
2018-03-19 10:13:47 -07:00
tests.WaitForHeight(resultTx.Height+1, port)
2018-03-19 10:13:47 -07:00
// check if tx was commited
assert.Equal(t, uint32(0), resultTx.CheckTx.Code)
assert.Equal(t, uint32(0), resultTx.DeliverTx.Code)
// query sender
acc = getAccount(t, port, addr)
2018-04-07 10:56:49 -07:00
coins := acc.GetCoins()
2018-03-19 10:13:47 -07:00
mycoins := coins[0]
assert.Equal(t, "steak", mycoins.Denom)
assert.Equal(t, initialBalance[0].Amount.SubRaw(1), mycoins.Amount)
2018-03-19 10:13:47 -07:00
2018-03-20 03:53:02 -07:00
// TODO: query ibc egress packet state
2018-03-19 10:13:47 -07:00
}
2018-03-14 05:01:55 -07:00
func TestTxs(t *testing.T) {
name, password := "test", "1234567890"
addr, seed := CreateAddr(t, "test", password, GetKB(t))
cleanup, _, port := InitializeTestLCD(t, 2, []sdk.Address{addr})
defer cleanup()
2018-03-14 05:01:55 -07:00
// query wrong
res, body := Request(t, port, "GET", "/txs", nil)
require.Equal(t, http.StatusBadRequest, res.StatusCode, body)
2018-03-14 05:01:55 -07:00
// query empty
res, body = Request(t, port, "GET", fmt.Sprintf("/txs?tag=sender_bech32='%s'", "cosmosaccaddr1jawd35d9aq4u76sr3fjalmcqc8hqygs9gtnmv3"), nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
assert.Equal(t, "[]", body)
2018-03-14 05:01:55 -07:00
// create TX
receiveAddr, resultTx := doSend(t, port, seed, name, password, addr)
2018-03-14 05:01:55 -07:00
tests.WaitForHeight(resultTx.Height+1, port)
2018-03-14 08:18:47 -07:00
// check if tx is findable
res, body = Request(t, port, "GET", fmt.Sprintf("/txs/%s", resultTx.Hash), nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
type txInfo struct {
Height int64 `json:"height"`
Tx sdk.Tx `json:"tx"`
Result abci.ResponseDeliverTx `json:"result"`
}
var indexedTxs []txInfo
// check if tx is queryable
res, body = Request(t, port, "GET", fmt.Sprintf("/txs?tag=tx.hash='%s'", resultTx.Hash), nil)
2018-03-14 05:01:55 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
assert.NotEqual(t, "[]", body)
err := cdc.UnmarshalJSON([]byte(body), &indexedTxs)
require.NoError(t, err)
assert.Equal(t, 1, len(indexedTxs))
2018-03-14 05:01:55 -07:00
// query sender
// also tests url decoding
addrBech := sdk.MustBech32ifyAcc(addr)
res, body = Request(t, port, "GET", "/txs?tag=sender_bech32=%27"+addrBech+"%27", nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-14 05:01:55 -07:00
err = cdc.UnmarshalJSON([]byte(body), &indexedTxs)
require.NoError(t, err)
require.Equal(t, 1, len(indexedTxs), "%v", indexedTxs) // there are 2 txs created with doSend
assert.Equal(t, resultTx.Height, indexedTxs[0].Height)
2018-03-14 05:01:55 -07:00
// query recipient
receiveAddrBech := sdk.MustBech32ifyAcc(receiveAddr)
res, body = Request(t, port, "GET", fmt.Sprintf("/txs?tag=recipient_bech32='%s'", receiveAddrBech), nil)
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-03-14 05:01:55 -07:00
err = cdc.UnmarshalJSON([]byte(body), &indexedTxs)
require.NoError(t, err)
require.Equal(t, 1, len(indexedTxs))
assert.Equal(t, resultTx.Height, indexedTxs[0].Height)
2018-03-14 05:01:55 -07:00
}
2018-05-28 23:07:03 -07:00
func TestValidatorsQuery(t *testing.T) {
cleanup, pks, port := InitializeTestLCD(t, 2, []sdk.Address{})
require.Equal(t, 2, len(pks))
defer cleanup()
validators := getValidators(t, port)
2018-05-28 23:07:03 -07:00
assert.Equal(t, len(validators), 2)
// make sure all the validators were found (order unknown because sorted by owner addr)
foundVal1, foundVal2 := false, false
pk1Bech := sdk.MustBech32ifyValPub(pks[0])
pk2Bech := sdk.MustBech32ifyValPub(pks[1])
if validators[0].PubKey == pk1Bech || validators[1].PubKey == pk1Bech {
foundVal1 = true
}
if validators[0].PubKey == pk2Bech || validators[1].PubKey == pk2Bech {
foundVal2 = true
}
assert.True(t, foundVal1, "pk1Bech %v, owner1 %v, owner2 %v", pk1Bech, validators[0].Owner, validators[1].Owner)
assert.True(t, foundVal2, "pk2Bech %v, owner1 %v, owner2 %v", pk2Bech, validators[0].Owner, validators[1].Owner)
2018-05-28 23:07:03 -07:00
}
func TestBonding(t *testing.T) {
name, password, denom := "test", "1234567890", "steak"
addr, seed := CreateAddr(t, "test", password, GetKB(t))
cleanup, pks, port := InitializeTestLCD(t, 2, []sdk.Address{addr})
defer cleanup()
validator1Owner := pks[0].Address()
2018-05-14 17:43:46 -07:00
// create bond TX
resultTx := doBond(t, port, seed, name, password, addr, validator1Owner)
2018-05-14 17:43:46 -07:00
tests.WaitForHeight(resultTx.Height+1, port)
// check if tx was commited
assert.Equal(t, uint32(0), resultTx.CheckTx.Code)
assert.Equal(t, uint32(0), resultTx.DeliverTx.Code)
// query sender
acc := getAccount(t, port, addr)
2018-05-14 17:43:46 -07:00
coins := acc.GetCoins()
assert.Equal(t, int64(40), coins.AmountOf(denom).Int64())
2018-05-14 17:43:46 -07:00
// query validator
bond := getDelegation(t, port, addr, validator1Owner)
assert.Equal(t, "60/1", bond.Shares.String())
2018-05-14 17:43:46 -07:00
//////////////////////
// testing unbonding
2018-05-14 17:43:46 -07:00
// create unbond TX
resultTx = doUnbond(t, port, seed, name, password, addr, validator1Owner)
2018-05-14 17:43:46 -07:00
tests.WaitForHeight(resultTx.Height+1, port)
// query validator
bond = getDelegation(t, port, addr, validator1Owner)
assert.Equal(t, "30/1", bond.Shares.String())
2018-05-14 17:43:46 -07:00
// check if tx was commited
assert.Equal(t, uint32(0), resultTx.CheckTx.Code)
assert.Equal(t, uint32(0), resultTx.DeliverTx.Code)
// TODO fix shares fn in staking
2018-05-14 17:43:46 -07:00
// query sender
2018-06-12 22:45:51 -07:00
//acc := getAccount(t, sendAddr)
//coins := acc.GetCoins()
//assert.Equal(t, int64(98), coins.AmountOf(coinDenom))
2018-03-10 09:33:05 -08:00
2018-03-05 08:41:50 -08:00
}
//_____________________________________________________________________________
// get the account to get the sequence
func getAccount(t *testing.T, port string, addr sdk.Address) auth.Account {
addrBech32 := sdk.MustBech32ifyAcc(addr)
res, body := Request(t, port, "GET", "/accounts/"+addrBech32, nil)
2018-04-07 10:56:49 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-05-23 22:09:01 -07:00
var acc auth.Account
2018-04-07 10:56:49 -07:00
err := cdc.UnmarshalJSON([]byte(body), &acc)
require.Nil(t, err)
return acc
}
func doSend(t *testing.T, port, seed, name, password string, addr sdk.Address) (receiveAddr sdk.Address, resultTx ctypes.ResultBroadcastTxCommit) {
2018-03-14 05:01:55 -07:00
// create receive address
kb := client.MockKeyBase()
receiveInfo, _, err := kb.Create("receive_address", "1234567890", cryptoKeys.CryptoAlgo("ed25519"))
require.Nil(t, err)
receiveAddr = receiveInfo.PubKey.Address()
receiveAddrBech := sdk.MustBech32ifyAcc(receiveAddr)
2018-03-14 05:01:55 -07:00
acc := getAccount(t, port, addr)
accnum := acc.GetAccountNumber()
2018-04-07 10:56:49 -07:00
sequence := acc.GetSequence()
2018-03-17 17:42:18 -07:00
2018-03-14 05:01:55 -07:00
// send
coinbz, err := json.Marshal(sdk.NewCoin("steak", 1))
if err != nil {
panic(err)
}
jsonStr := []byte(fmt.Sprintf(`{
"name":"%s",
"password":"%s",
"account_number":%d,
"sequence":%d,
"gas": 10000,
"amount":[%s]
}`, name, password, accnum, sequence, coinbz))
res, body := Request(t, port, "POST", "/accounts/"+receiveAddrBech+"/send", jsonStr)
2018-03-14 05:01:55 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-04-07 10:56:49 -07:00
err = cdc.UnmarshalJSON([]byte(body), &resultTx)
2018-03-14 08:18:47 -07:00
require.Nil(t, err)
2018-03-17 17:42:18 -07:00
return receiveAddr, resultTx
2018-03-14 05:01:55 -07:00
}
2018-03-19 10:13:47 -07:00
func doIBCTransfer(t *testing.T, port, seed, name, password string, addr sdk.Address) (resultTx ctypes.ResultBroadcastTxCommit) {
2018-03-19 10:13:47 -07:00
// create receive address
kb := client.MockKeyBase()
receiveInfo, _, err := kb.Create("receive_address", "1234567890", cryptoKeys.CryptoAlgo("ed25519"))
require.Nil(t, err)
receiveAddr := receiveInfo.PubKey.Address()
receiveAddrBech := sdk.MustBech32ifyAcc(receiveAddr)
2018-03-19 10:13:47 -07:00
// get the account to get the sequence
acc := getAccount(t, port, addr)
accnum := acc.GetAccountNumber()
2018-04-07 10:56:49 -07:00
sequence := acc.GetSequence()
2018-03-19 10:13:47 -07:00
// send
jsonStr := []byte(fmt.Sprintf(`{
"name":"%s",
"password": "%s",
"account_number":%d,
"sequence": %d,
"gas": 100000,
"amount":[
{
"denom": "%s",
"amount": 1
}
]
}`, name, password, accnum, sequence, "steak"))
res, body := Request(t, port, "POST", "/ibc/testchain/"+receiveAddrBech+"/send", jsonStr)
2018-03-19 10:13:47 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-04-07 10:56:49 -07:00
err = cdc.UnmarshalJSON([]byte(body), &resultTx)
2018-03-19 10:13:47 -07:00
require.Nil(t, err)
2018-03-20 03:53:02 -07:00
return resultTx
2018-03-19 10:13:47 -07:00
}
2018-05-14 17:43:46 -07:00
func getDelegation(t *testing.T, port string, delegatorAddr, validatorAddr sdk.Address) stake.Delegation {
delegatorAddrBech := sdk.MustBech32ifyAcc(delegatorAddr)
validatorAddrBech := sdk.MustBech32ifyVal(validatorAddr)
2018-05-14 17:43:46 -07:00
// get the account to get the sequence
res, body := Request(t, port, "GET", "/stake/"+delegatorAddrBech+"/bonding_status/"+validatorAddrBech, nil)
2018-05-14 17:43:46 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
var bond stake.Delegation
2018-05-14 17:43:46 -07:00
err := cdc.UnmarshalJSON([]byte(body), &bond)
require.Nil(t, err)
return bond
}
func doBond(t *testing.T, port, seed, name, password string, delegatorAddr, validatorAddr sdk.Address) (resultTx ctypes.ResultBroadcastTxCommit) {
2018-05-14 17:43:46 -07:00
// get the account to get the sequence
acc := getAccount(t, port, delegatorAddr)
accnum := acc.GetAccountNumber()
2018-05-14 17:43:46 -07:00
sequence := acc.GetSequence()
delegatorAddrBech := sdk.MustBech32ifyAcc(delegatorAddr)
validatorAddrBech := sdk.MustBech32ifyVal(validatorAddr)
2018-05-14 17:43:46 -07:00
// send
jsonStr := []byte(fmt.Sprintf(`{
"name": "%s",
"password": "%s",
"account_number": %d,
2018-05-14 17:43:46 -07:00
"sequence": %d,
"gas": 10000,
2018-05-26 01:37:39 -07:00
"delegate": [
2018-05-14 17:43:46 -07:00
{
"delegator_addr": "%s",
2018-05-26 01:37:39 -07:00
"validator_addr": "%s",
"bond": { "denom": "%s", "amount": 60 }
2018-05-14 17:43:46 -07:00
}
],
"unbond": []
}`, name, password, accnum, sequence, delegatorAddrBech, validatorAddrBech, "steak"))
res, body := Request(t, port, "POST", "/stake/delegations", jsonStr)
2018-05-14 17:43:46 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-05-20 18:46:09 -07:00
var results []ctypes.ResultBroadcastTxCommit
err := cdc.UnmarshalJSON([]byte(body), &results)
2018-05-14 17:43:46 -07:00
require.Nil(t, err)
2018-05-20 18:46:09 -07:00
return results[0]
2018-05-14 17:43:46 -07:00
}
func doUnbond(t *testing.T, port, seed, name, password string, delegatorAddr, validatorAddr sdk.Address) (resultTx ctypes.ResultBroadcastTxCommit) {
2018-05-14 17:43:46 -07:00
// get the account to get the sequence
acc := getAccount(t, port, delegatorAddr)
accnum := acc.GetAccountNumber()
2018-05-14 17:43:46 -07:00
sequence := acc.GetSequence()
delegatorAddrBech := sdk.MustBech32ifyAcc(delegatorAddr)
validatorAddrBech := sdk.MustBech32ifyVal(validatorAddr)
2018-05-14 17:43:46 -07:00
// send
jsonStr := []byte(fmt.Sprintf(`{
"name": "%s",
"password": "%s",
"account_number": %d,
2018-05-14 17:43:46 -07:00
"sequence": %d,
"gas": 10000,
"delegate": [],
2018-05-14 17:43:46 -07:00
"unbond": [
{
"delegator_addr": "%s",
2018-05-26 01:37:39 -07:00
"validator_addr": "%s",
"shares": "30"
2018-05-14 17:43:46 -07:00
}
]
}`, name, password, accnum, sequence, delegatorAddrBech, validatorAddrBech))
res, body := Request(t, port, "POST", "/stake/delegations", jsonStr)
2018-05-14 17:43:46 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
2018-05-20 18:46:09 -07:00
var results []ctypes.ResultBroadcastTxCommit
err := cdc.UnmarshalJSON([]byte(body), &results)
2018-05-14 17:43:46 -07:00
require.Nil(t, err)
2018-05-20 18:46:09 -07:00
return results[0]
2018-05-14 17:43:46 -07:00
}
func getValidators(t *testing.T, port string) []stakerest.StakeValidatorOutput {
2018-05-14 17:43:46 -07:00
// get the account to get the sequence
res, body := Request(t, port, "GET", "/stake/validators", nil)
2018-05-14 17:43:46 -07:00
require.Equal(t, http.StatusOK, res.StatusCode, body)
var validators []stakerest.StakeValidatorOutput
2018-05-28 23:07:03 -07:00
err := cdc.UnmarshalJSON([]byte(body), &validators)
2018-05-14 17:43:46 -07:00
require.Nil(t, err)
2018-05-28 23:07:03 -07:00
return validators
2018-05-14 17:43:46 -07:00
}