prysm-pulse/slasher/beaconclient/receivers_test.go
Ivan Martinez 8334aac111
Batch saving of attestations from stream for slasher (#5041)
* Batch saving of attestations from stream for slasher

* Progress on test

* Fixes

* Fix test

* Rename

* Modify logs and timing

* Change

Co-authored-by: Raul Jordan <raul@prysmaticlabs.com>
2020-03-09 12:49:40 -05:00

122 lines
3.1 KiB
Go

package beaconclient
import (
"context"
"testing"
"time"
ptypes "github.com/gogo/protobuf/types"
"github.com/golang/mock/gomock"
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
"github.com/prysmaticlabs/prysm/shared/event"
"github.com/prysmaticlabs/prysm/shared/mock"
testDB "github.com/prysmaticlabs/prysm/slasher/db/testing"
)
func TestService_ReceiveBlocks(t *testing.T) {
ctrl := gomock.NewController(t)
defer ctrl.Finish()
client := mock.NewMockBeaconChainClient(ctrl)
bs := Service{
beaconClient: client,
blockFeed: new(event.Feed),
}
stream := mock.NewMockBeaconChain_StreamBlocksClient(ctrl)
ctx, cancel := context.WithCancel(context.Background())
client.EXPECT().StreamBlocks(
gomock.Any(),
&ptypes.Empty{},
).Return(stream, nil)
stream.EXPECT().Context().Return(ctx).AnyTimes()
stream.EXPECT().Recv().Return(
&ethpb.SignedBeaconBlock{},
nil,
).Do(func() {
cancel()
})
bs.receiveBlocks(ctx)
}
func TestService_ReceiveAttestations(t *testing.T) {
ctrl := gomock.NewController(t)
defer ctrl.Finish()
client := mock.NewMockBeaconChainClient(ctrl)
bs := Service{
beaconClient: client,
blockFeed: new(event.Feed),
receivedAttestationsBuffer: make(chan *ethpb.IndexedAttestation, 1),
collectedAttestationsBuffer: make(chan []*ethpb.IndexedAttestation, 1),
}
stream := mock.NewMockBeaconChain_StreamIndexedAttestationsClient(ctrl)
ctx, cancel := context.WithCancel(context.Background())
att := &ethpb.IndexedAttestation{
Data: &ethpb.AttestationData{
Slot: 5,
},
}
client.EXPECT().StreamIndexedAttestations(
gomock.Any(),
&ptypes.Empty{},
).Return(stream, nil)
stream.EXPECT().Context().Return(ctx).AnyTimes()
stream.EXPECT().Recv().Return(
att,
nil,
).Do(func() {
cancel()
})
bs.receiveAttestations(ctx)
}
func TestService_ReceiveAttestations_Batched(t *testing.T) {
ctrl := gomock.NewController(t)
defer ctrl.Finish()
client := mock.NewMockBeaconChainClient(ctrl)
bs := Service{
beaconClient: client,
blockFeed: new(event.Feed),
slasherDB: testDB.SetupSlasherDB(t, false),
attestationFeed: new(event.Feed),
receivedAttestationsBuffer: make(chan *ethpb.IndexedAttestation, 1),
collectedAttestationsBuffer: make(chan []*ethpb.IndexedAttestation, 1),
}
stream := mock.NewMockBeaconChain_StreamIndexedAttestationsClient(ctrl)
ctx, cancel := context.WithCancel(context.Background())
att := &ethpb.IndexedAttestation{
Data: &ethpb.AttestationData{
Slot: 5,
Target: &ethpb.Checkpoint{
Epoch: 5,
},
},
Signature: []byte{1, 2},
}
client.EXPECT().StreamIndexedAttestations(
gomock.Any(),
&ptypes.Empty{},
).Return(stream, nil)
stream.EXPECT().Context().Return(ctx).AnyTimes()
stream.EXPECT().Recv().Return(
att,
nil,
).Do(func() {
time.Sleep(2*time.Second)
cancel()
})
go bs.receiveAttestations(ctx)
bs.receivedAttestationsBuffer <- att
att.Data.Target.Epoch = 6
bs.receivedAttestationsBuffer <- att
att.Data.Target.Epoch = 8
bs.receivedAttestationsBuffer <- att
atts := <- bs.collectedAttestationsBuffer
if len(atts) != 3 {
t.Fatalf("Expected %d received attestations to be batched", len(atts))
}
}