prysm-pulse/beacon-chain/core/randao/randao_test.go

44 lines
1.2 KiB
Go

package randao
import (
"testing"
"github.com/prysmaticlabs/prysm/beacon-chain/core/types"
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
"github.com/prysmaticlabs/prysm/shared/params"
)
func TestUpdateRandaoLayers(t *testing.T) {
beaconState, err := types.NewGenesisBeaconState(nil)
if err != nil {
t.Fatalf("failed to generate beacon state: %v", err)
}
var shardAndCommittees []*pb.ShardAndCommitteeArray
for i := uint64(0); i < params.BeaconConfig().EpochLength*2; i++ {
shardAndCommittees = append(shardAndCommittees, &pb.ShardAndCommitteeArray{
ArrayShardAndCommittee: []*pb.ShardAndCommittee{
{Committee: []uint32{9, 8, 311, 12, 92, 1, 23, 17}},
},
})
}
beaconState.SetShardAndCommitteesAtSlots(shardAndCommittees)
newState, err := UpdateRandaoLayers(beaconState, 1)
if err != nil {
t.Fatalf("failed to update randao layers: %v", err)
}
vreg := newState.ValidatorRegistry()
// Since slot 1 has proposer index 8
if vreg[8].GetRandaoLayers() != 1 {
t.Fatalf("randao layers not updated %d", vreg[9].GetRandaoLayers())
}
if vreg[9].GetRandaoLayers() != 0 {
t.Errorf("randao layers updated when they were not supposed to %d", vreg[9].GetRandaoLayers())
}
}