package migration import ( "testing" "github.com/prysmaticlabs/go-bitfield" fieldparams "github.com/prysmaticlabs/prysm/config/fieldparams" types "github.com/prysmaticlabs/prysm/consensus-types/primitives" "github.com/prysmaticlabs/prysm/consensus-types/wrapper" "github.com/prysmaticlabs/prysm/encoding/bytesutil" ethpbv1 "github.com/prysmaticlabs/prysm/proto/eth/v1" ethpbalpha "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1" "github.com/prysmaticlabs/prysm/testing/assert" "github.com/prysmaticlabs/prysm/testing/require" "github.com/prysmaticlabs/prysm/testing/util" ) var ( slot = types.Slot(1) epoch = types.Epoch(1) validatorIndex = types.ValidatorIndex(1) committeeIndex = types.CommitteeIndex(1) depositCount = uint64(2) attestingIndices = []uint64{1, 2} blockNumber = uint64(10) gasLimit = uint64(10) gasUsed = uint64(10) timestamp = uint64(10) parentRoot = bytesutil.PadTo([]byte("parentroot"), fieldparams.RootLength) stateRoot = bytesutil.PadTo([]byte("stateroot"), fieldparams.RootLength) signature = bytesutil.PadTo([]byte("signature"), 96) randaoReveal = bytesutil.PadTo([]byte("randaoreveal"), 96) depositRoot = bytesutil.PadTo([]byte("depositroot"), fieldparams.RootLength) blockHash = bytesutil.PadTo([]byte("blockhash"), 32) beaconBlockRoot = bytesutil.PadTo([]byte("beaconblockroot"), fieldparams.RootLength) sourceRoot = bytesutil.PadTo([]byte("sourceroot"), fieldparams.RootLength) targetRoot = bytesutil.PadTo([]byte("targetroot"), fieldparams.RootLength) bodyRoot = bytesutil.PadTo([]byte("bodyroot"), fieldparams.RootLength) selectionProof = bytesutil.PadTo([]byte("selectionproof"), 96) parentHash = bytesutil.PadTo([]byte("parenthash"), 32) feeRecipient = bytesutil.PadTo([]byte("feerecipient"), 20) receiptsRoot = bytesutil.PadTo([]byte("receiptsroot"), 32) logsBloom = bytesutil.PadTo([]byte("logsbloom"), 256) prevRandao = bytesutil.PadTo([]byte("prevrandao"), 32) extraData = bytesutil.PadTo([]byte("extradata"), 32) baseFeePerGas = bytesutil.PadTo([]byte("basefeepergas"), 32) transactionsRoot = bytesutil.PadTo([]byte("transactions"), 32) aggregationBits = bitfield.Bitlist{0x01} ) func Test_BlockIfaceToV1BlockHeader(t *testing.T) { alphaBlock := util.HydrateSignedBeaconBlock(ðpbalpha.SignedBeaconBlock{}) alphaBlock.Block.Slot = slot alphaBlock.Block.ProposerIndex = validatorIndex alphaBlock.Block.ParentRoot = parentRoot alphaBlock.Block.StateRoot = stateRoot alphaBlock.Signature = signature wsb, err := wrapper.WrappedSignedBeaconBlock(alphaBlock) require.NoError(t, err) v1Header, err := BlockIfaceToV1BlockHeader(wsb) require.NoError(t, err) bodyRoot, err := alphaBlock.Block.Body.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, bodyRoot[:], v1Header.Message.BodyRoot) assert.Equal(t, slot, v1Header.Message.Slot) assert.Equal(t, validatorIndex, v1Header.Message.ProposerIndex) assert.DeepEqual(t, parentRoot, v1Header.Message.ParentRoot) assert.DeepEqual(t, stateRoot, v1Header.Message.StateRoot) assert.DeepEqual(t, signature, v1Header.Signature) } func Test_V1Alpha1AggregateAttAndProofToV1(t *testing.T) { proof := [32]byte{1} att := util.HydrateAttestation(ðpbalpha.Attestation{ Data: ðpbalpha.AttestationData{ Slot: 5, }, }) alpha := ðpbalpha.AggregateAttestationAndProof{ AggregatorIndex: 1, Aggregate: att, SelectionProof: proof[:], } v1 := V1Alpha1AggregateAttAndProofToV1(alpha) assert.Equal(t, v1.AggregatorIndex, types.ValidatorIndex(1)) assert.DeepSSZEqual(t, v1.Aggregate.Data.Slot, att.Data.Slot) assert.DeepEqual(t, v1.SelectionProof, proof[:]) } func Test_V1Alpha1ToV1SignedBlock(t *testing.T) { alphaBlock := util.HydrateSignedBeaconBlock(ðpbalpha.SignedBeaconBlock{}) alphaBlock.Block.Slot = slot alphaBlock.Block.ProposerIndex = validatorIndex alphaBlock.Block.ParentRoot = parentRoot alphaBlock.Block.StateRoot = stateRoot alphaBlock.Block.Body.RandaoReveal = randaoReveal alphaBlock.Block.Body.Eth1Data = ðpbalpha.Eth1Data{ DepositRoot: depositRoot, DepositCount: depositCount, BlockHash: blockHash, } alphaBlock.Signature = signature v1Block, err := V1Alpha1ToV1SignedBlock(alphaBlock) require.NoError(t, err) alphaRoot, err := alphaBlock.HashTreeRoot() require.NoError(t, err) v1Root, err := v1Block.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, alphaRoot, v1Root) } func Test_V1ToV1Alpha1SignedBlock(t *testing.T) { v1Block := util.HydrateV1SignedBeaconBlock(ðpbv1.SignedBeaconBlock{}) v1Block.Block.Slot = slot v1Block.Block.ProposerIndex = validatorIndex v1Block.Block.ParentRoot = parentRoot v1Block.Block.StateRoot = stateRoot v1Block.Block.Body.RandaoReveal = randaoReveal v1Block.Block.Body.Eth1Data = ðpbv1.Eth1Data{ DepositRoot: depositRoot, DepositCount: depositCount, BlockHash: blockHash, } v1Block.Signature = signature alphaBlock, err := V1ToV1Alpha1SignedBlock(v1Block) require.NoError(t, err) alphaRoot, err := alphaBlock.HashTreeRoot() require.NoError(t, err) v1Root, err := v1Block.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, v1Root, alphaRoot) } func Test_V1ToV1Alpha1Block(t *testing.T) { alphaBlock := util.HydrateBeaconBlock(ðpbalpha.BeaconBlock{}) alphaBlock.Slot = slot alphaBlock.ProposerIndex = validatorIndex alphaBlock.ParentRoot = parentRoot alphaBlock.StateRoot = stateRoot alphaBlock.Body.RandaoReveal = randaoReveal alphaBlock.Body.Eth1Data = ðpbalpha.Eth1Data{ DepositRoot: depositRoot, DepositCount: depositCount, BlockHash: blockHash, } v1Block, err := V1Alpha1ToV1Block(alphaBlock) require.NoError(t, err) v1Root, err := v1Block.HashTreeRoot() require.NoError(t, err) alphaRoot, err := alphaBlock.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, alphaRoot, v1Root) } func Test_V1Alpha1AttSlashingToV1(t *testing.T) { alphaAttestation := ðpbalpha.IndexedAttestation{ AttestingIndices: attestingIndices, Data: ðpbalpha.AttestationData{ Slot: slot, CommitteeIndex: committeeIndex, BeaconBlockRoot: beaconBlockRoot, Source: ðpbalpha.Checkpoint{ Epoch: epoch, Root: sourceRoot, }, Target: ðpbalpha.Checkpoint{ Epoch: epoch, Root: targetRoot, }, }, Signature: signature, } alphaSlashing := ðpbalpha.AttesterSlashing{ Attestation_1: alphaAttestation, Attestation_2: alphaAttestation, } v1Slashing := V1Alpha1AttSlashingToV1(alphaSlashing) alphaRoot, err := alphaSlashing.HashTreeRoot() require.NoError(t, err) v1Root, err := v1Slashing.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, alphaRoot, v1Root) } func Test_V1Alpha1ProposerSlashingToV1(t *testing.T) { alphaHeader := util.HydrateSignedBeaconHeader(ðpbalpha.SignedBeaconBlockHeader{}) alphaHeader.Header.Slot = slot alphaHeader.Header.ProposerIndex = validatorIndex alphaHeader.Header.ParentRoot = parentRoot alphaHeader.Header.StateRoot = stateRoot alphaHeader.Header.BodyRoot = bodyRoot alphaHeader.Signature = signature alphaSlashing := ðpbalpha.ProposerSlashing{ Header_1: alphaHeader, Header_2: alphaHeader, } v1Slashing := V1Alpha1ProposerSlashingToV1(alphaSlashing) alphaRoot, err := alphaSlashing.HashTreeRoot() require.NoError(t, err) v1Root, err := v1Slashing.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, alphaRoot, v1Root) } func Test_V1Alpha1ExitToV1(t *testing.T) { alphaExit := ðpbalpha.SignedVoluntaryExit{ Exit: ðpbalpha.VoluntaryExit{ Epoch: epoch, ValidatorIndex: validatorIndex, }, Signature: signature, } v1Exit := V1Alpha1ExitToV1(alphaExit) alphaRoot, err := alphaExit.HashTreeRoot() require.NoError(t, err) v1Root, err := v1Exit.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, alphaRoot, v1Root) } func Test_V1ExitToV1Alpha1(t *testing.T) { v1Exit := ðpbv1.SignedVoluntaryExit{ Message: ðpbv1.VoluntaryExit{ Epoch: epoch, ValidatorIndex: validatorIndex, }, Signature: signature, } alphaExit := V1ExitToV1Alpha1(v1Exit) alphaRoot, err := alphaExit.HashTreeRoot() require.NoError(t, err) v1Root, err := v1Exit.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, alphaRoot, v1Root) } func Test_V1AttSlashingToV1Alpha1(t *testing.T) { v1Attestation := ðpbv1.IndexedAttestation{ AttestingIndices: attestingIndices, Data: ðpbv1.AttestationData{ Slot: slot, Index: committeeIndex, BeaconBlockRoot: beaconBlockRoot, Source: ðpbv1.Checkpoint{ Epoch: epoch, Root: sourceRoot, }, Target: ðpbv1.Checkpoint{ Epoch: epoch, Root: targetRoot, }, }, Signature: signature, } v1Slashing := ðpbv1.AttesterSlashing{ Attestation_1: v1Attestation, Attestation_2: v1Attestation, } alphaSlashing := V1AttSlashingToV1Alpha1(v1Slashing) alphaRoot, err := alphaSlashing.HashTreeRoot() require.NoError(t, err) v1Root, err := v1Slashing.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, v1Root, alphaRoot) } func Test_V1ProposerSlashingToV1Alpha1(t *testing.T) { v1Header := ðpbv1.SignedBeaconBlockHeader{ Message: ðpbv1.BeaconBlockHeader{ Slot: slot, ProposerIndex: validatorIndex, ParentRoot: parentRoot, StateRoot: stateRoot, BodyRoot: bodyRoot, }, Signature: signature, } v1Slashing := ðpbv1.ProposerSlashing{ SignedHeader_1: v1Header, SignedHeader_2: v1Header, } alphaSlashing := V1ProposerSlashingToV1Alpha1(v1Slashing) alphaRoot, err := alphaSlashing.HashTreeRoot() require.NoError(t, err) v1Root, err := v1Slashing.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, alphaRoot, v1Root) } func Test_V1Alpha1AttToV1(t *testing.T) { alphaAtt := ðpbalpha.Attestation{ AggregationBits: aggregationBits, Data: ðpbalpha.AttestationData{ Slot: slot, CommitteeIndex: committeeIndex, BeaconBlockRoot: beaconBlockRoot, Source: ðpbalpha.Checkpoint{ Epoch: epoch, Root: sourceRoot, }, Target: ðpbalpha.Checkpoint{ Epoch: epoch, Root: targetRoot, }, }, Signature: signature, } v1Att := V1Alpha1AttestationToV1(alphaAtt) v1Root, err := v1Att.HashTreeRoot() require.NoError(t, err) alphaRoot, err := alphaAtt.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, v1Root, alphaRoot) } func Test_V1AttToV1Alpha1(t *testing.T) { v1Att := ðpbv1.Attestation{ AggregationBits: aggregationBits, Data: ðpbv1.AttestationData{ Slot: slot, Index: committeeIndex, BeaconBlockRoot: beaconBlockRoot, Source: ðpbv1.Checkpoint{ Epoch: epoch, Root: sourceRoot, }, Target: ðpbv1.Checkpoint{ Epoch: epoch, Root: targetRoot, }, }, Signature: signature, } alphaAtt := V1AttToV1Alpha1(v1Att) alphaRoot, err := alphaAtt.HashTreeRoot() require.NoError(t, err) v1Root, err := v1Att.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, v1Root, alphaRoot) } func Test_BlockInterfaceToV1Block(t *testing.T) { v1Alpha1Block := util.HydrateSignedBeaconBlock(ðpbalpha.SignedBeaconBlock{}) v1Alpha1Block.Block.Slot = slot v1Alpha1Block.Block.ProposerIndex = validatorIndex v1Alpha1Block.Block.ParentRoot = parentRoot v1Alpha1Block.Block.StateRoot = stateRoot v1Alpha1Block.Block.Body.RandaoReveal = randaoReveal v1Alpha1Block.Block.Body.Eth1Data = ðpbalpha.Eth1Data{ DepositRoot: depositRoot, DepositCount: depositCount, BlockHash: blockHash, } v1Alpha1Block.Signature = signature wsb, err := wrapper.WrappedSignedBeaconBlock(v1Alpha1Block) require.NoError(t, err) v1Block, err := SignedBeaconBlock(wsb) require.NoError(t, err) v1Root, err := v1Block.HashTreeRoot() require.NoError(t, err) v1Alpha1Root, err := v1Alpha1Block.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, v1Root, v1Alpha1Root) } func Test_V1Alpha1ValidatorToV1(t *testing.T) { v1Alpha1Validator := ðpbalpha.Validator{ PublicKey: []byte("pubkey"), WithdrawalCredentials: []byte("withdraw"), EffectiveBalance: 99, Slashed: true, ActivationEligibilityEpoch: 1, ActivationEpoch: 11, ExitEpoch: 111, WithdrawableEpoch: 1111, } v1Validator := V1Alpha1ValidatorToV1(v1Alpha1Validator) require.NotNil(t, v1Validator) assert.DeepEqual(t, []byte("pubkey"), v1Validator.Pubkey) assert.DeepEqual(t, []byte("withdraw"), v1Validator.WithdrawalCredentials) assert.Equal(t, uint64(99), v1Validator.EffectiveBalance) assert.Equal(t, true, v1Validator.Slashed) assert.Equal(t, types.Epoch(1), v1Validator.ActivationEligibilityEpoch) assert.Equal(t, types.Epoch(11), v1Validator.ActivationEpoch) assert.Equal(t, types.Epoch(111), v1Validator.ExitEpoch) assert.Equal(t, types.Epoch(1111), v1Validator.WithdrawableEpoch) } func Test_V1ValidatorToV1Alpha1(t *testing.T) { v1Validator := ðpbv1.Validator{ Pubkey: []byte("pubkey"), WithdrawalCredentials: []byte("withdraw"), EffectiveBalance: 99, Slashed: true, ActivationEligibilityEpoch: 1, ActivationEpoch: 11, ExitEpoch: 111, WithdrawableEpoch: 1111, } v1Alpha1Validator := V1ValidatorToV1Alpha1(v1Validator) require.NotNil(t, v1Alpha1Validator) assert.DeepEqual(t, []byte("pubkey"), v1Alpha1Validator.PublicKey) assert.DeepEqual(t, []byte("withdraw"), v1Alpha1Validator.WithdrawalCredentials) assert.Equal(t, uint64(99), v1Alpha1Validator.EffectiveBalance) assert.Equal(t, true, v1Alpha1Validator.Slashed) assert.Equal(t, types.Epoch(1), v1Alpha1Validator.ActivationEligibilityEpoch) assert.Equal(t, types.Epoch(11), v1Alpha1Validator.ActivationEpoch) assert.Equal(t, types.Epoch(111), v1Alpha1Validator.ExitEpoch) assert.Equal(t, types.Epoch(1111), v1Alpha1Validator.WithdrawableEpoch) } func Test_V1SignedAggregateAttAndProofToV1Alpha1(t *testing.T) { v1Att := ðpbv1.SignedAggregateAttestationAndProof{ Message: ðpbv1.AggregateAttestationAndProof{ AggregatorIndex: 1, Aggregate: util.HydrateV1Attestation(ðpbv1.Attestation{}), SelectionProof: selectionProof, }, Signature: signature, } v1Alpha1Att := V1SignedAggregateAttAndProofToV1Alpha1(v1Att) v1Root, err := v1Att.HashTreeRoot() require.NoError(t, err) v1Alpha1Root, err := v1Alpha1Att.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, v1Root, v1Alpha1Root) } func Test_V1AttestationToV1Alpha1(t *testing.T) { v1Att := util.HydrateV1Attestation(ðpbv1.Attestation{}) v1Alpha1Att := V1AttToV1Alpha1(v1Att) v1Root, err := v1Att.HashTreeRoot() require.NoError(t, err) v1Alpha1Root, err := v1Alpha1Att.HashTreeRoot() require.NoError(t, err) assert.DeepEqual(t, v1Root, v1Alpha1Root) } func TestBeaconStateToProto(t *testing.T) { source, err := util.NewBeaconState(util.FillRootsNaturalOpt, func(state *ethpbalpha.BeaconState) error { state.GenesisTime = 1 state.GenesisValidatorsRoot = bytesutil.PadTo([]byte("genesisvalidatorsroot"), 32) state.Slot = 2 state.Fork = ðpbalpha.Fork{ PreviousVersion: bytesutil.PadTo([]byte("123"), 4), CurrentVersion: bytesutil.PadTo([]byte("456"), 4), Epoch: 3, } state.LatestBlockHeader = ðpbalpha.BeaconBlockHeader{ Slot: 4, ProposerIndex: 5, ParentRoot: bytesutil.PadTo([]byte("lbhparentroot"), 32), StateRoot: bytesutil.PadTo([]byte("lbhstateroot"), 32), BodyRoot: bytesutil.PadTo([]byte("lbhbodyroot"), 32), } state.BlockRoots = [][]byte{bytesutil.PadTo([]byte("blockroots"), 32)} state.StateRoots = [][]byte{bytesutil.PadTo([]byte("stateroots"), 32)} state.HistoricalRoots = [][]byte{bytesutil.PadTo([]byte("historicalroots"), 32)} state.Eth1Data = ðpbalpha.Eth1Data{ DepositRoot: bytesutil.PadTo([]byte("e1ddepositroot"), 32), DepositCount: 6, BlockHash: bytesutil.PadTo([]byte("e1dblockhash"), 32), } state.Eth1DataVotes = []*ethpbalpha.Eth1Data{{ DepositRoot: bytesutil.PadTo([]byte("e1dvdepositroot"), 32), DepositCount: 7, BlockHash: bytesutil.PadTo([]byte("e1dvblockhash"), 32), }} state.Eth1DepositIndex = 8 state.Validators = []*ethpbalpha.Validator{{ PublicKey: bytesutil.PadTo([]byte("publickey"), 48), WithdrawalCredentials: bytesutil.PadTo([]byte("withdrawalcredentials"), 32), EffectiveBalance: 9, Slashed: true, ActivationEligibilityEpoch: 10, ActivationEpoch: 11, ExitEpoch: 12, WithdrawableEpoch: 13, }} state.Balances = []uint64{14} state.RandaoMixes = [][]byte{bytesutil.PadTo([]byte("randaomixes"), 32)} state.Slashings = []uint64{15} state.PreviousEpochAttestations = []*ethpbalpha.PendingAttestation{{ AggregationBits: bitfield.Bitlist{16}, Data: ðpbalpha.AttestationData{ Slot: 17, CommitteeIndex: 18, BeaconBlockRoot: bytesutil.PadTo([]byte("peabeaconblockroot"), 32), Source: ðpbalpha.Checkpoint{ Epoch: 19, Root: bytesutil.PadTo([]byte("peasroot"), 32), }, Target: ðpbalpha.Checkpoint{ Epoch: 20, Root: bytesutil.PadTo([]byte("peatroot"), 32), }, }, InclusionDelay: 21, ProposerIndex: 22, }} state.CurrentEpochAttestations = []*ethpbalpha.PendingAttestation{{ AggregationBits: bitfield.Bitlist{23}, Data: ðpbalpha.AttestationData{ Slot: 24, CommitteeIndex: 25, BeaconBlockRoot: bytesutil.PadTo([]byte("ceabeaconblockroot"), 32), Source: ðpbalpha.Checkpoint{ Epoch: 26, Root: bytesutil.PadTo([]byte("ceasroot"), 32), }, Target: ðpbalpha.Checkpoint{ Epoch: 27, Root: bytesutil.PadTo([]byte("ceatroot"), 32), }, }, InclusionDelay: 28, ProposerIndex: 29, }} state.JustificationBits = bitfield.Bitvector4{1} state.PreviousJustifiedCheckpoint = ðpbalpha.Checkpoint{ Epoch: 30, Root: bytesutil.PadTo([]byte("pjcroot"), 32), } state.CurrentJustifiedCheckpoint = ðpbalpha.Checkpoint{ Epoch: 31, Root: bytesutil.PadTo([]byte("cjcroot"), 32), } state.FinalizedCheckpoint = ðpbalpha.Checkpoint{ Epoch: 32, Root: bytesutil.PadTo([]byte("fcroot"), 32), } return nil }) require.NoError(t, err) result, err := BeaconStateToProto(source) require.NoError(t, err) require.NotNil(t, result) assert.Equal(t, uint64(1), result.GenesisTime) assert.DeepEqual(t, bytesutil.PadTo([]byte("genesisvalidatorsroot"), 32), result.GenesisValidatorsRoot) assert.Equal(t, types.Slot(2), result.Slot) resultFork := result.Fork require.NotNil(t, resultFork) assert.DeepEqual(t, bytesutil.PadTo([]byte("123"), 4), resultFork.PreviousVersion) assert.DeepEqual(t, bytesutil.PadTo([]byte("456"), 4), resultFork.CurrentVersion) assert.Equal(t, types.Epoch(3), resultFork.Epoch) resultLatestBlockHeader := result.LatestBlockHeader require.NotNil(t, resultLatestBlockHeader) assert.Equal(t, types.Slot(4), resultLatestBlockHeader.Slot) assert.Equal(t, types.ValidatorIndex(5), resultLatestBlockHeader.ProposerIndex) assert.DeepEqual(t, bytesutil.PadTo([]byte("lbhparentroot"), 32), resultLatestBlockHeader.ParentRoot) assert.DeepEqual(t, bytesutil.PadTo([]byte("lbhstateroot"), 32), resultLatestBlockHeader.StateRoot) assert.DeepEqual(t, bytesutil.PadTo([]byte("lbhbodyroot"), 32), resultLatestBlockHeader.BodyRoot) assert.DeepEqual(t, [][]byte{bytesutil.PadTo([]byte("blockroots"), 32)}, result.BlockRoots) assert.DeepEqual(t, [][]byte{bytesutil.PadTo([]byte("stateroots"), 32)}, result.StateRoots) assert.DeepEqual(t, [][]byte{bytesutil.PadTo([]byte("historicalroots"), 32)}, result.HistoricalRoots) resultEth1Data := result.Eth1Data require.NotNil(t, resultEth1Data) assert.DeepEqual(t, bytesutil.PadTo([]byte("e1ddepositroot"), 32), resultEth1Data.DepositRoot) assert.Equal(t, uint64(6), resultEth1Data.DepositCount) assert.DeepEqual(t, bytesutil.PadTo([]byte("e1dblockhash"), 32), resultEth1Data.BlockHash) require.Equal(t, 1, len(result.Eth1DataVotes)) resultEth1DataVote := result.Eth1DataVotes[0] require.NotNil(t, resultEth1DataVote) assert.DeepEqual(t, bytesutil.PadTo([]byte("e1dvdepositroot"), 32), resultEth1DataVote.DepositRoot) assert.Equal(t, uint64(7), resultEth1DataVote.DepositCount) assert.DeepEqual(t, bytesutil.PadTo([]byte("e1dvblockhash"), 32), resultEth1DataVote.BlockHash) assert.Equal(t, uint64(8), result.Eth1DepositIndex) require.Equal(t, 1, len(result.Validators)) resultValidator := result.Validators[0] require.NotNil(t, resultValidator) assert.DeepEqual(t, bytesutil.PadTo([]byte("publickey"), 48), resultValidator.Pubkey) assert.DeepEqual(t, bytesutil.PadTo([]byte("withdrawalcredentials"), 32), resultValidator.WithdrawalCredentials) assert.Equal(t, uint64(9), resultValidator.EffectiveBalance) assert.Equal(t, true, resultValidator.Slashed) assert.Equal(t, types.Epoch(10), resultValidator.ActivationEligibilityEpoch) assert.Equal(t, types.Epoch(11), resultValidator.ActivationEpoch) assert.Equal(t, types.Epoch(12), resultValidator.ExitEpoch) assert.Equal(t, types.Epoch(13), resultValidator.WithdrawableEpoch) assert.DeepEqual(t, []uint64{14}, result.Balances) assert.DeepEqual(t, [][]byte{bytesutil.PadTo([]byte("randaomixes"), 32)}, result.RandaoMixes) assert.DeepEqual(t, []uint64{15}, result.Slashings) require.Equal(t, 1, len(result.PreviousEpochAttestations)) resultPrevEpochAtt := result.PreviousEpochAttestations[0] require.NotNil(t, resultPrevEpochAtt) assert.DeepEqual(t, bitfield.Bitlist{16}, resultPrevEpochAtt.AggregationBits) resultPrevEpochAttData := resultPrevEpochAtt.Data require.NotNil(t, resultPrevEpochAttData) assert.Equal(t, types.Slot(17), resultPrevEpochAttData.Slot) assert.Equal(t, types.CommitteeIndex(18), resultPrevEpochAttData.Index) assert.DeepEqual(t, bytesutil.PadTo([]byte("peabeaconblockroot"), 32), resultPrevEpochAttData.BeaconBlockRoot) resultPrevEpochAttSource := resultPrevEpochAttData.Source require.NotNil(t, resultPrevEpochAttSource) assert.Equal(t, types.Epoch(19), resultPrevEpochAttSource.Epoch) assert.DeepEqual(t, bytesutil.PadTo([]byte("peasroot"), 32), resultPrevEpochAttSource.Root) resultPrevEpochAttTarget := resultPrevEpochAttData.Target require.NotNil(t, resultPrevEpochAttTarget) assert.Equal(t, types.Epoch(20), resultPrevEpochAttTarget.Epoch) assert.DeepEqual(t, bytesutil.PadTo([]byte("peatroot"), 32), resultPrevEpochAttTarget.Root) assert.Equal(t, types.Slot(21), resultPrevEpochAtt.InclusionDelay) assert.Equal(t, types.ValidatorIndex(22), resultPrevEpochAtt.ProposerIndex) resultCurrEpochAtt := result.CurrentEpochAttestations[0] require.NotNil(t, resultCurrEpochAtt) assert.DeepEqual(t, bitfield.Bitlist{23}, resultCurrEpochAtt.AggregationBits) resultCurrEpochAttData := resultCurrEpochAtt.Data require.NotNil(t, resultCurrEpochAttData) assert.Equal(t, types.Slot(24), resultCurrEpochAttData.Slot) assert.Equal(t, types.CommitteeIndex(25), resultCurrEpochAttData.Index) assert.DeepEqual(t, bytesutil.PadTo([]byte("ceabeaconblockroot"), 32), resultCurrEpochAttData.BeaconBlockRoot) resultCurrEpochAttSource := resultCurrEpochAttData.Source require.NotNil(t, resultCurrEpochAttSource) assert.Equal(t, types.Epoch(26), resultCurrEpochAttSource.Epoch) assert.DeepEqual(t, bytesutil.PadTo([]byte("ceasroot"), 32), resultCurrEpochAttSource.Root) resultCurrEpochAttTarget := resultCurrEpochAttData.Target require.NotNil(t, resultCurrEpochAttTarget) assert.Equal(t, types.Epoch(27), resultCurrEpochAttTarget.Epoch) assert.DeepEqual(t, bytesutil.PadTo([]byte("ceatroot"), 32), resultCurrEpochAttTarget.Root) assert.Equal(t, types.Slot(28), resultCurrEpochAtt.InclusionDelay) assert.Equal(t, types.ValidatorIndex(29), resultCurrEpochAtt.ProposerIndex) assert.DeepEqual(t, bitfield.Bitvector4{1}, result.JustificationBits) resultPrevJustifiedCheckpoint := result.PreviousJustifiedCheckpoint require.NotNil(t, resultPrevJustifiedCheckpoint) assert.Equal(t, types.Epoch(30), resultPrevJustifiedCheckpoint.Epoch) assert.DeepEqual(t, bytesutil.PadTo([]byte("pjcroot"), 32), resultPrevJustifiedCheckpoint.Root) resultCurrJustifiedCheckpoint := result.CurrentJustifiedCheckpoint require.NotNil(t, resultCurrJustifiedCheckpoint) assert.Equal(t, types.Epoch(31), resultCurrJustifiedCheckpoint.Epoch) assert.DeepEqual(t, bytesutil.PadTo([]byte("cjcroot"), 32), resultCurrJustifiedCheckpoint.Root) resultFinalizedCheckpoint := result.FinalizedCheckpoint require.NotNil(t, resultFinalizedCheckpoint) assert.Equal(t, types.Epoch(32), resultFinalizedCheckpoint.Epoch) assert.DeepEqual(t, bytesutil.PadTo([]byte("fcroot"), 32), resultFinalizedCheckpoint.Root) }