mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2024-12-26 05:17:22 +00:00
a9a4bb9163
* move testutil * util pkg * build * gaz Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
194 lines
4.7 KiB
Go
194 lines
4.7 KiB
Go
package altair_test
|
|
|
|
import (
|
|
"math"
|
|
"testing"
|
|
|
|
types "github.com/prysmaticlabs/eth2-types"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/altair"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/state"
|
|
"github.com/prysmaticlabs/prysm/config/params"
|
|
"github.com/prysmaticlabs/prysm/testing/require"
|
|
"github.com/prysmaticlabs/prysm/testing/util"
|
|
)
|
|
|
|
func Test_BaseReward(t *testing.T) {
|
|
genState := func(valCount uint64) state.ReadOnlyBeaconState {
|
|
s, _ := util.DeterministicGenesisStateAltair(t, valCount)
|
|
return s
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
valIdx types.ValidatorIndex
|
|
st state.ReadOnlyBeaconState
|
|
want uint64
|
|
errString string
|
|
}{
|
|
{
|
|
name: "unknown validator",
|
|
valIdx: 2,
|
|
st: genState(1),
|
|
want: 0,
|
|
errString: "index 2 out of range",
|
|
},
|
|
{
|
|
name: "active balance is 32eth",
|
|
valIdx: 0,
|
|
st: genState(1),
|
|
want: 11448672,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is 32eth * target committee size",
|
|
valIdx: 0,
|
|
st: genState(params.BeaconConfig().TargetCommitteeSize),
|
|
want: 1011904,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is 32eth * max validator per committee size",
|
|
valIdx: 0,
|
|
st: genState(params.BeaconConfig().MaxValidatorsPerCommittee),
|
|
want: 252960,
|
|
errString: "",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
got, err := altair.BaseReward(tt.st, tt.valIdx)
|
|
if (err != nil) && (tt.errString != "") {
|
|
require.ErrorContains(t, tt.errString, err)
|
|
return
|
|
}
|
|
require.Equal(t, tt.want, got)
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_BaseRewardWithTotalBalance(t *testing.T) {
|
|
s, _ := util.DeterministicGenesisStateAltair(t, 1)
|
|
tests := []struct {
|
|
name string
|
|
valIdx types.ValidatorIndex
|
|
activeBalance uint64
|
|
want uint64
|
|
errString string
|
|
}{
|
|
{
|
|
name: "active balance is 0",
|
|
valIdx: 0,
|
|
activeBalance: 0,
|
|
want: 0,
|
|
errString: "active balance can't be 0",
|
|
},
|
|
{
|
|
name: "unknown validator",
|
|
valIdx: 2,
|
|
activeBalance: 1,
|
|
want: 0,
|
|
errString: "index 2 out of range",
|
|
},
|
|
{
|
|
name: "active balance is 1",
|
|
valIdx: 0,
|
|
activeBalance: 1,
|
|
want: 2048000000000,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is 1eth",
|
|
valIdx: 0,
|
|
activeBalance: params.BeaconConfig().EffectiveBalanceIncrement,
|
|
want: 64765024,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is 32eth",
|
|
valIdx: 0,
|
|
activeBalance: params.BeaconConfig().MaxEffectiveBalance,
|
|
want: 11448672,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is 32eth * 1m validators",
|
|
valIdx: 0,
|
|
activeBalance: params.BeaconConfig().MaxEffectiveBalance * 1e9,
|
|
want: 544,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is max uint64",
|
|
valIdx: 0,
|
|
activeBalance: math.MaxUint64,
|
|
want: 448,
|
|
errString: "",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
got, err := altair.BaseRewardWithTotalBalance(s, tt.valIdx, tt.activeBalance)
|
|
if (err != nil) && (tt.errString != "") {
|
|
require.ErrorContains(t, tt.errString, err)
|
|
return
|
|
}
|
|
require.Equal(t, tt.want, got)
|
|
})
|
|
}
|
|
}
|
|
|
|
func Test_BaseRewardPerIncrement(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
activeBalance uint64
|
|
want uint64
|
|
errString string
|
|
}{
|
|
{
|
|
name: "active balance is 0",
|
|
activeBalance: 0,
|
|
want: 0,
|
|
errString: "active balance can't be 0",
|
|
},
|
|
{
|
|
name: "active balance is 1",
|
|
activeBalance: 1,
|
|
want: 64000000000,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is 1eth",
|
|
activeBalance: params.BeaconConfig().EffectiveBalanceIncrement,
|
|
want: 2023907,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is 32eth",
|
|
activeBalance: params.BeaconConfig().MaxEffectiveBalance,
|
|
want: 357771,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is 32eth * 1m validators",
|
|
activeBalance: params.BeaconConfig().MaxEffectiveBalance * 1e9,
|
|
want: 17,
|
|
errString: "",
|
|
},
|
|
{
|
|
name: "active balance is max uint64",
|
|
activeBalance: math.MaxUint64,
|
|
want: 14,
|
|
errString: "",
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
got, err := altair.BaseRewardPerIncrement(tt.activeBalance)
|
|
if (err != nil) && (tt.errString != "") {
|
|
require.ErrorContains(t, tt.errString, err)
|
|
return
|
|
}
|
|
require.Equal(t, tt.want, got)
|
|
})
|
|
}
|
|
}
|