diff --git a/x/emissions/keeper/params_test.go b/x/emissions/keeper/params_test.go index e73031b824..2594c1e99a 100644 --- a/x/emissions/keeper/params_test.go +++ b/x/emissions/keeper/params_test.go @@ -3,6 +3,7 @@ package keeper_test import ( "testing" + sdkmath "cosmossdk.io/math" "github.com/stretchr/testify/require" keepertest "github.com/zeta-chain/zetacore/testutil/keeper" emissionstypes "github.com/zeta-chain/zetacore/x/emissions/types" @@ -10,9 +11,9 @@ import ( func TestKeeper_GetParams(t *testing.T) { tests := []struct { - name string - params emissionstypes.Params - isPanic string + name string + params emissionstypes.Params + isErr string }{ { name: "Successfully set params", @@ -25,8 +26,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "", + isErr: "", }, { name: "negative observer slashed amount", @@ -39,8 +41,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(-100000000000000000), }, - isPanic: "slash amount cannot be less than 0", + isErr: "slash amount cannot be less than 0", }, { name: "MaxBondFactor too high", @@ -53,8 +56,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "max bond factor cannot be higher that 0.25", + isErr: "max bond factor cannot be higher that 0.25", }, { name: "MinBondFactor too low", @@ -67,8 +71,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "min bond factor cannot be lower that 0.75", + isErr: "min bond factor cannot be lower that 0.75", }, { name: "invalid block time", @@ -81,8 +86,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "invalid block time", + isErr: "invalid block time", }, { name: "invalid block time less than 0", @@ -95,8 +101,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "block time cannot be less than or equal to 0", + isErr: "block time cannot be less than or equal to 0", }, { name: "bond ratio too high", @@ -109,8 +116,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "target bond ratio cannot be more than 100 percent", + isErr: "target bond ratio cannot be more than 100 percent", }, { name: "bond ratio too low", @@ -123,8 +131,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "target bond ratio cannot be less than 0 percent", + isErr: "target bond ratio cannot be less than 0 percent", }, { name: "validator emission percentage too high", @@ -137,8 +146,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "validator emission percentage cannot be more than 100 percent", + isErr: "validator emission percentage cannot be more than 100 percent", }, { name: "validator emission percentage too low", @@ -151,8 +161,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "validator emission percentage cannot be less than 0 percent", + isErr: "validator emission percentage cannot be less than 0 percent", }, { name: "observer percentage too low", @@ -165,8 +176,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "-00.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "observer emission percentage cannot be less than 0 percent", + isErr: "observer emission percentage cannot be less than 0 percent", }, { name: "observer percentage too high", @@ -179,8 +191,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "150.25", TssSignerEmissionPercentage: "00.25", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "observer emission percentage cannot be more than 100 percent", + isErr: "observer emission percentage cannot be more than 100 percent", }, { name: "tss signer percentage too high", @@ -193,8 +206,9 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "102.22", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "tss emission percentage cannot be more than 100 percent", + isErr: "tss emission percentage cannot be more than 100 percent", }, { name: "tss signer percentage too low", @@ -207,20 +221,19 @@ func TestKeeper_GetParams(t *testing.T) { ObserverEmissionPercentage: "00.25", TssSignerEmissionPercentage: "-102.22", DurationFactorConstant: "0.001877876953694702", + ObserverSlashAmount: sdkmath.NewInt(100000000000000000), }, - isPanic: "tss emission percentage cannot be less than 0 percent", + isErr: "tss emission percentage cannot be less than 0 percent", }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) { k, ctx, _, _ := keepertest.EmissionsKeeper(t) - assertPanic(t, func() { - k.SetParams(ctx, tt.params) - }, tt.isPanic) - - if tt.isPanic != "" { - require.Equal(t, emissionstypes.DefaultParams(), k.GetParams(ctx)) + err := k.SetParams(ctx, tt.params) + if tt.isErr != "" { + require.Error(t, err) } else { + require.NoError(t, err) require.Equal(t, tt.params, k.GetParams(ctx)) } }) diff --git a/x/emissions/types/params.go b/x/emissions/types/params.go index 05bb8943a5..b11aa6749e 100644 --- a/x/emissions/types/params.go +++ b/x/emissions/types/params.go @@ -31,6 +31,33 @@ func DefaultParams() Params { // Validate validates the set of params func (p Params) Validate() error { + if err := validateMaxBondFactor(p.MaxBondFactor); err != nil { + return err + } + if err := validateMinBondFactor(p.MinBondFactor); err != nil { + return err + } + if err := validateAvgBlockTime(p.AvgBlockTime); err != nil { + return err + } + if err := validateTargetBondRatio(p.TargetBondRatio); err != nil { + return err + } + if err := validateValidatorEmissionPercentage(p.ValidatorEmissionPercentage); err != nil { + return err + } + if err := validateObserverEmissionPercentage(p.ObserverEmissionPercentage); err != nil { + return err + } + if err := validateTssEmissionPercentage(p.TssSignerEmissionPercentage); err != nil { + return err + } + if err := validateDurationFactorConstant(p.DurationFactorConstant); err != nil { + return err + } + if err := validateObserverSlashAmount(p.ObserverSlashAmount); err != nil { + return err + } return nil } @@ -149,3 +176,14 @@ func validateTssEmissionPercentage(i interface{}) error { } return nil } + +func validateObserverSlashAmount(i interface{}) error { + v, ok := i.(sdkmath.Int) + if !ok { + return fmt.Errorf("invalid parameter type: %T", i) + } + if v.LT(sdk.ZeroInt()) { + return fmt.Errorf("slash amount cannot be less than 0") + } + return nil +} diff --git a/x/emissions/types/params_test.go b/x/emissions/types/params_test.go index 0f6ed5fd55..8ee527b547 100644 --- a/x/emissions/types/params_test.go +++ b/x/emissions/types/params_test.go @@ -24,17 +24,6 @@ func TestNewParams(t *testing.T) { require.Equal(t, sdkmath.NewInt(100000000000000000), params.ObserverSlashAmount, "ObserverSlashAmount should be set to 100000000000000000") } -func TestParamKeyTable(t *testing.T) { - kt := ParamKeyTable() - - ps := Params{} - for _, psp := range ps.ParamSetPairs() { - require.PanicsWithValue(t, "duplicate parameter key", func() { - kt.RegisterType(psp) - }) - } -} - func TestDefaultParams(t *testing.T) { params := DefaultParams() diff --git a/x/observer/types/params.go b/x/observer/types/params.go index 1a500f7b62..2c69eacd5a 100644 --- a/x/observer/types/params.go +++ b/x/observer/types/params.go @@ -48,6 +48,12 @@ func DefaultAdminPolicy() []*Admin_Policy { // Validate validates the set of params func (p Params) Validate() error { + if err := validateAdminPolicy(p.AdminPolicy); err != nil { + return err + } + if err := validateBallotMaturityBlocks(p.BallotMaturityBlocks); err != nil { + return err + } return nil }