126 lines
4.4 KiB
Go
126 lines
4.4 KiB
Go
package slashing
|
|
|
|
import (
|
|
"testing"
|
|
|
|
sdk "github.com/cosmos/cosmos-sdk/types"
|
|
"github.com/cosmos/cosmos-sdk/x/auth"
|
|
"github.com/cosmos/cosmos-sdk/x/bank"
|
|
"github.com/cosmos/cosmos-sdk/x/mock"
|
|
"github.com/cosmos/cosmos-sdk/x/params"
|
|
"github.com/cosmos/cosmos-sdk/x/stake"
|
|
"github.com/stretchr/testify/require"
|
|
abci "github.com/tendermint/tendermint/abci/types"
|
|
"github.com/tendermint/tendermint/crypto/ed25519"
|
|
)
|
|
|
|
var (
|
|
priv1 = ed25519.GenPrivKey()
|
|
addr1 = sdk.AccAddress(priv1.PubKey().Address())
|
|
coins = sdk.Coins{sdk.NewInt64Coin("foocoin", 10)}
|
|
)
|
|
|
|
// initialize the mock application for this module
|
|
func getMockApp(t *testing.T) (*mock.App, stake.Keeper, Keeper) {
|
|
mapp := mock.NewApp()
|
|
|
|
RegisterCodec(mapp.Cdc)
|
|
keyStake := sdk.NewKVStoreKey("stake")
|
|
tkeyStake := sdk.NewTransientStoreKey("transient_stake")
|
|
keySlashing := sdk.NewKVStoreKey("slashing")
|
|
keyParams := sdk.NewKVStoreKey("params")
|
|
bankKeeper := bank.NewBaseKeeper(mapp.AccountMapper)
|
|
paramsKeeper := params.NewKeeper(mapp.Cdc, keyParams)
|
|
stakeKeeper := stake.NewKeeper(mapp.Cdc, keyStake, tkeyStake, bankKeeper, mapp.RegisterCodespace(stake.DefaultCodespace))
|
|
|
|
keeper := NewKeeper(mapp.Cdc, keySlashing, stakeKeeper, paramsKeeper.Getter(), mapp.RegisterCodespace(DefaultCodespace))
|
|
mapp.Router().AddRoute("stake", stake.NewHandler(stakeKeeper))
|
|
mapp.Router().AddRoute("slashing", NewHandler(keeper))
|
|
|
|
mapp.SetEndBlocker(getEndBlocker(stakeKeeper))
|
|
mapp.SetInitChainer(getInitChainer(mapp, stakeKeeper))
|
|
require.NoError(t, mapp.CompleteSetup(keyStake, keySlashing, keyParams, tkeyStake))
|
|
|
|
return mapp, stakeKeeper, keeper
|
|
}
|
|
|
|
// stake endblocker
|
|
func getEndBlocker(keeper stake.Keeper) sdk.EndBlocker {
|
|
return func(ctx sdk.Context, req abci.RequestEndBlock) abci.ResponseEndBlock {
|
|
validatorUpdates := stake.EndBlocker(ctx, keeper)
|
|
return abci.ResponseEndBlock{
|
|
ValidatorUpdates: validatorUpdates,
|
|
}
|
|
}
|
|
}
|
|
|
|
// overwrite the mock init chainer
|
|
func getInitChainer(mapp *mock.App, keeper stake.Keeper) sdk.InitChainer {
|
|
return func(ctx sdk.Context, req abci.RequestInitChain) abci.ResponseInitChain {
|
|
mapp.InitChainer(ctx, req)
|
|
stakeGenesis := stake.DefaultGenesisState()
|
|
stakeGenesis.Pool.LooseTokens = sdk.NewDec(100000)
|
|
validators, err := stake.InitGenesis(ctx, keeper, stakeGenesis)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
|
|
return abci.ResponseInitChain{
|
|
Validators: validators,
|
|
}
|
|
}
|
|
}
|
|
|
|
func checkValidator(t *testing.T, mapp *mock.App, keeper stake.Keeper,
|
|
addr sdk.AccAddress, expFound bool) stake.Validator {
|
|
ctxCheck := mapp.BaseApp.NewContext(true, abci.Header{})
|
|
validator, found := keeper.GetValidator(ctxCheck, sdk.ValAddress(addr1))
|
|
require.Equal(t, expFound, found)
|
|
return validator
|
|
}
|
|
|
|
func checkValidatorSigningInfo(t *testing.T, mapp *mock.App, keeper Keeper,
|
|
addr sdk.ConsAddress, expFound bool) ValidatorSigningInfo {
|
|
ctxCheck := mapp.BaseApp.NewContext(true, abci.Header{})
|
|
signingInfo, found := keeper.getValidatorSigningInfo(ctxCheck, addr)
|
|
require.Equal(t, expFound, found)
|
|
return signingInfo
|
|
}
|
|
|
|
func TestSlashingMsgs(t *testing.T) {
|
|
mapp, stakeKeeper, keeper := getMockApp(t)
|
|
|
|
genCoin := sdk.NewInt64Coin("steak", 42)
|
|
bondCoin := sdk.NewInt64Coin("steak", 10)
|
|
|
|
acc1 := &auth.BaseAccount{
|
|
Address: addr1,
|
|
Coins: sdk.Coins{genCoin},
|
|
}
|
|
accs := []auth.Account{acc1}
|
|
mock.SetGenesis(mapp, accs)
|
|
|
|
description := stake.NewDescription("foo_moniker", "", "", "")
|
|
commission := stake.NewCommissionMsg(sdk.ZeroDec(), sdk.ZeroDec(), sdk.ZeroDec())
|
|
|
|
createValidatorMsg := stake.NewMsgCreateValidator(
|
|
sdk.ValAddress(addr1), priv1.PubKey(), bondCoin, description, commission,
|
|
)
|
|
mock.SignCheckDeliver(t, mapp.BaseApp, []sdk.Msg{createValidatorMsg}, []int64{0}, []int64{0}, true, true, priv1)
|
|
mock.CheckBalance(t, mapp, addr1, sdk.Coins{genCoin.Minus(bondCoin)})
|
|
mapp.BeginBlock(abci.RequestBeginBlock{})
|
|
|
|
validator := checkValidator(t, mapp, stakeKeeper, addr1, true)
|
|
require.Equal(t, sdk.ValAddress(addr1), validator.OperatorAddr)
|
|
require.Equal(t, sdk.Bonded, validator.Status)
|
|
require.True(sdk.DecEq(t, sdk.NewDec(10), validator.BondedTokens()))
|
|
unjailMsg := MsgUnjail{ValidatorAddr: sdk.ValAddress(validator.ConsPubKey.Address())}
|
|
|
|
// no signing info yet
|
|
checkValidatorSigningInfo(t, mapp, keeper, sdk.ConsAddress(addr1), false)
|
|
|
|
// unjail should fail with unknown validator
|
|
res := mock.SignCheckDeliver(t, mapp.BaseApp, []sdk.Msg{unjailMsg}, []int64{0}, []int64{1}, false, false, priv1)
|
|
require.Equal(t, sdk.ToABCICode(DefaultCodespace, CodeValidatorNotJailed), res.Code)
|
|
}
|