prysm-pulse/slasher/beaconclient/historical_data_retrieval_test.go
Victor Farazdagi a069738c20
ETH2 Types: Slot (#8408)
* update shared/params

* update eth2-types deps

* update protobufs

* update shared/*

* fix testutil/state

* update beacon-chain/state

* update beacon-chain/db

* update tests

* fix test

* update beacon-chain/core

* update beacon-chain/blockchain

* update beacon-chain/cache

* beacon-chain/forkchoice

* update beacon-chain/operations

* update beacon-chain/p2p

* update beacon-chain/rpc

* update sync/initial-sync

* update deps

* update deps

* go fmt

* update beacon-chain/sync

* update endtoend/

* bazel build //beacon-chain - works w/o issues

* update slasher code

* udpate tools/

* update validator/

* update fastssz

* fix build

* fix test building

* update tests

* update ethereumapis deps

* fix tests

* update state/stategen

* fix build

* fix test

* add FarFutureSlot

* go imports

* Radek's suggestions

* Ivan's suggestions

* type conversions

* Nishant's suggestions

* add more tests to rpc_send_request

* fix test

* clean up

* fix conflicts

Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
Co-authored-by: nisdas <nishdas93@gmail.com>
2021-02-16 07:45:34 +00:00

87 lines
2.6 KiB
Go

package beaconclient
import (
"context"
"strconv"
"testing"
"github.com/golang/mock/gomock"
"github.com/prysmaticlabs/eth2-types"
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
"github.com/prysmaticlabs/prysm/shared/mock"
"github.com/prysmaticlabs/prysm/shared/params"
"github.com/prysmaticlabs/prysm/shared/testutil/assert"
"github.com/prysmaticlabs/prysm/shared/testutil/require"
testDB "github.com/prysmaticlabs/prysm/slasher/db/testing"
logTest "github.com/sirupsen/logrus/hooks/test"
)
func TestService_RequestHistoricalAttestations(t *testing.T) {
params.SetupTestConfigCleanup(t)
hook := logTest.NewGlobal()
ctrl := gomock.NewController(t)
defer ctrl.Finish()
db := testDB.SetupSlasherDB(t, false)
client := mock.NewMockBeaconChainClient(ctrl)
bs := Service{
beaconClient: client,
slasherDB: db,
}
numAtts := 1000
wanted := make([]*ethpb.IndexedAttestation, numAtts)
for i := 0; i < numAtts; i++ {
wanted[i] = &ethpb.IndexedAttestation{
AttestingIndices: []uint64{1, 2, 3},
Data: &ethpb.AttestationData{
Slot: types.Slot(i),
Target: &ethpb.Checkpoint{
Epoch: 1,
Root: make([]byte, 32),
},
},
}
}
// We override the page size in the requests to 100 so we will
// obtain 10 pages of indexed attestations from the server.
numPages := 100
perPage := numAtts / numPages
cfg := params.BeaconConfig()
cfg.DefaultPageSize = perPage
params.OverrideBeaconConfig(cfg)
// We expect there to be numPages calls to ListIndexedAttestations
// to retrieve all attestations for epoch 0.
for i := 0; i < numAtts; i += perPage {
if i+perPage >= numAtts {
client.EXPECT().ListIndexedAttestations(
gomock.Any(),
gomock.Any(),
).Return(&ethpb.ListIndexedAttestationsResponse{
IndexedAttestations: wanted[i:],
NextPageToken: "",
TotalSize: int32(numAtts),
}, nil)
} else {
client.EXPECT().ListIndexedAttestations(
gomock.Any(),
gomock.Any(),
).Return(&ethpb.ListIndexedAttestationsResponse{
IndexedAttestations: wanted[i : i+perPage],
NextPageToken: strconv.Itoa(i + 1),
TotalSize: int32(numAtts),
}, nil)
}
}
// We request attestations for epoch 0.
res, err := bs.RequestHistoricalAttestations(context.Background(), 0)
require.NoError(t, err)
assert.DeepEqual(t, wanted, res)
require.LogsContain(t, hook, "Retrieved 100/1000 indexed attestations for epoch 0")
require.LogsContain(t, hook, "Retrieved 500/1000 indexed attestations for epoch 0")
require.LogsContain(t, hook, "Retrieved 1000/1000 indexed attestations for epoch 0")
}