109 lines
3.4 KiB
Go
109 lines
3.4 KiB
Go
package main
|
|
|
|
import (
|
|
"encoding/hex"
|
|
"math/big"
|
|
"strconv"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
// Register standby validator and vote for it.
|
|
// We don't create a new account here, because chain will
|
|
// stop working after validator will change.
|
|
func TestRegisterCandidate(t *testing.T) {
|
|
e := newExecutor(t, true)
|
|
|
|
e.In.WriteString("one\r")
|
|
e.Run(t, "neo-go", "wallet", "nep17", "multitransfer",
|
|
"--rpc-endpoint", "http://"+e.RPC.Addr,
|
|
"--wallet", validatorWallet,
|
|
"--from", validatorAddr,
|
|
"NEO:"+validatorPriv.Address()+":10",
|
|
"GAS:"+validatorPriv.Address()+":10000")
|
|
e.checkTxPersisted(t)
|
|
|
|
// missing address
|
|
e.RunWithError(t, "neo-go", "wallet", "candidate", "register",
|
|
"--rpc-endpoint", "http://"+e.RPC.Addr,
|
|
"--wallet", validatorWallet)
|
|
|
|
e.In.WriteString("one\r")
|
|
e.Run(t, "neo-go", "wallet", "candidate", "register",
|
|
"--rpc-endpoint", "http://"+e.RPC.Addr,
|
|
"--wallet", validatorWallet,
|
|
"--address", validatorPriv.Address())
|
|
e.checkTxPersisted(t)
|
|
|
|
vs, err := e.Chain.GetEnrollments()
|
|
require.NoError(t, err)
|
|
require.Equal(t, 1, len(vs))
|
|
require.Equal(t, validatorPriv.PublicKey(), vs[0].Key)
|
|
require.Equal(t, big.NewInt(0), vs[0].Votes)
|
|
|
|
t.Run("VoteUnvote", func(t *testing.T) {
|
|
e.In.WriteString("one\r")
|
|
e.Run(t, "neo-go", "wallet", "candidate", "vote",
|
|
"--rpc-endpoint", "http://"+e.RPC.Addr,
|
|
"--wallet", validatorWallet,
|
|
"--address", validatorPriv.Address(),
|
|
"--candidate", hex.EncodeToString(validatorPriv.PublicKey().Bytes()))
|
|
_, index := e.checkTxPersisted(t)
|
|
|
|
vs, err = e.Chain.GetEnrollments()
|
|
require.Equal(t, 1, len(vs))
|
|
require.Equal(t, validatorPriv.PublicKey(), vs[0].Key)
|
|
b, _ := e.Chain.GetGoverningTokenBalance(validatorPriv.GetScriptHash())
|
|
require.Equal(t, b, vs[0].Votes)
|
|
|
|
// check state
|
|
e.Run(t, "neo-go", "wallet", "candidate", "getstate",
|
|
"--rpc-endpoint", "http://"+e.RPC.Addr,
|
|
"--address", validatorPriv.Address())
|
|
e.checkNextLine(t, "^\\s*Voted:\\s+"+validatorPriv.Address())
|
|
e.checkNextLine(t, "^\\s*Amount\\s*:\\s*"+b.String()+"$")
|
|
e.checkNextLine(t, "^\\s*Block\\s*:\\s*"+strconv.FormatUint(uint64(index), 10))
|
|
e.checkEOF(t)
|
|
|
|
// unvote
|
|
e.In.WriteString("one\r")
|
|
e.Run(t, "neo-go", "wallet", "candidate", "vote",
|
|
"--rpc-endpoint", "http://"+e.RPC.Addr,
|
|
"--wallet", validatorWallet,
|
|
"--address", validatorPriv.Address())
|
|
_, index = e.checkTxPersisted(t)
|
|
|
|
vs, err = e.Chain.GetEnrollments()
|
|
require.Equal(t, 1, len(vs))
|
|
require.Equal(t, validatorPriv.PublicKey(), vs[0].Key)
|
|
require.Equal(t, big.NewInt(0), vs[0].Votes)
|
|
|
|
// check state
|
|
e.Run(t, "neo-go", "wallet", "candidate", "getstate",
|
|
"--rpc-endpoint", "http://"+e.RPC.Addr,
|
|
"--address", validatorPriv.Address())
|
|
e.checkNextLine(t, "^\\s*Voted:\\s+"+"null") // no vote.
|
|
e.checkNextLine(t, "^\\s*Amount\\s*:\\s*"+b.String()+"$")
|
|
e.checkNextLine(t, "^\\s*Block\\s*:\\s*"+strconv.FormatUint(uint64(index), 10))
|
|
e.checkEOF(t)
|
|
})
|
|
|
|
// missing address
|
|
e.RunWithError(t, "neo-go", "wallet", "candidate", "unregister",
|
|
"--rpc-endpoint", "http://"+e.RPC.Addr,
|
|
"--wallet", validatorWallet)
|
|
|
|
e.In.WriteString("one\r")
|
|
e.Run(t, "neo-go", "wallet", "candidate", "unregister",
|
|
"--rpc-endpoint", "http://"+e.RPC.Addr,
|
|
"--wallet", validatorWallet,
|
|
"--address", validatorPriv.Address())
|
|
e.checkTxPersisted(t)
|
|
|
|
vs, err = e.Chain.GetEnrollments()
|
|
require.Equal(t, 0, len(vs))
|
|
|
|
// getstate: missing address
|
|
e.RunWithError(t, "neo-go", "wallet", "candidate", "getstate")
|
|
}
|