2020-02-19 22:26:14 +00:00
|
|
|
package beaconclient
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"reflect"
|
|
|
|
"strconv"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/golang/mock/gomock"
|
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/mock"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
2020-08-13 16:22:25 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/require"
|
2020-02-27 17:22:39 +00:00
|
|
|
testDB "github.com/prysmaticlabs/prysm/slasher/db/testing"
|
2020-02-19 22:26:14 +00:00
|
|
|
logTest "github.com/sirupsen/logrus/hooks/test"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestService_RequestHistoricalAttestations(t *testing.T) {
|
2020-05-05 08:39:38 +00:00
|
|
|
params.SetupTestConfigCleanup(t)
|
2020-02-19 22:26:14 +00:00
|
|
|
hook := logTest.NewGlobal()
|
|
|
|
ctrl := gomock.NewController(t)
|
|
|
|
defer ctrl.Finish()
|
2020-02-27 17:22:39 +00:00
|
|
|
db := testDB.SetupSlasherDB(t, false)
|
2020-02-19 22:26:14 +00:00
|
|
|
client := mock.NewMockBeaconChainClient(ctrl)
|
|
|
|
|
|
|
|
bs := Service{
|
|
|
|
beaconClient: client,
|
2020-02-27 17:22:39 +00:00
|
|
|
slasherDB: db,
|
2020-02-19 22:26:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
numAtts := 1000
|
|
|
|
wanted := make([]*ethpb.IndexedAttestation, numAtts)
|
|
|
|
for i := 0; i < numAtts; i++ {
|
|
|
|
wanted[i] = ðpb.IndexedAttestation{
|
|
|
|
AttestingIndices: []uint64{1, 2, 3},
|
|
|
|
Data: ðpb.AttestationData{
|
|
|
|
Slot: uint64(i),
|
2020-02-27 17:22:39 +00:00
|
|
|
Target: ðpb.Checkpoint{
|
|
|
|
Epoch: 1,
|
|
|
|
Root: make([]byte, 32),
|
|
|
|
},
|
2020-02-19 22:26:14 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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(ðpb.ListIndexedAttestationsResponse{
|
|
|
|
IndexedAttestations: wanted[i:],
|
|
|
|
NextPageToken: "",
|
|
|
|
TotalSize: int32(numAtts),
|
|
|
|
}, nil)
|
|
|
|
} else {
|
|
|
|
client.EXPECT().ListIndexedAttestations(
|
|
|
|
gomock.Any(),
|
|
|
|
gomock.Any(),
|
|
|
|
).Return(ðpb.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)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if !reflect.DeepEqual(res, wanted) {
|
|
|
|
t.Errorf("Wanted %v, received %v", wanted, res)
|
|
|
|
}
|
2020-08-13 16:22:25 +00:00
|
|
|
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")
|
2020-02-19 22:26:14 +00:00
|
|
|
}
|