mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-09 03:01:19 +00:00
44 lines
1.2 KiB
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())
|
||
|
}
|
||
|
}
|