prysm-pulse/slasher/beaconclient/chain_data_test.go
Shay Zluf c1a8b41347
Is slashable block rpc endpoint implementation (#5765)
* is slashable block rpc endpoint implementation

* add span

* raul feedback

* fix error

Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com>
2020-05-08 08:51:56 +03:00

89 lines
2.4 KiB
Go

package beaconclient
import (
"bytes"
"context"
"testing"
"time"
"github.com/gogo/protobuf/proto"
"github.com/golang/mock/gomock"
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
"github.com/prysmaticlabs/prysm/shared/mock"
"github.com/prysmaticlabs/prysm/shared/testutil"
logTest "github.com/sirupsen/logrus/hooks/test"
)
func TestService_ChainHead(t *testing.T) {
ctrl := gomock.NewController(t)
defer ctrl.Finish()
client := mock.NewMockBeaconChainClient(ctrl)
bs := Service{
beaconClient: client,
}
wanted := &ethpb.ChainHead{
HeadSlot: 4,
HeadEpoch: 0,
HeadBlockRoot: make([]byte, 32),
}
client.EXPECT().GetChainHead(gomock.Any(), gomock.Any()).Return(wanted, nil)
res, err := bs.ChainHead(context.Background())
if err != nil {
t.Fatal(err)
}
if !proto.Equal(res, wanted) {
t.Errorf("Wanted %v, received %v", wanted, res)
}
}
func TestService_GenesisValidatorsRoot(t *testing.T) {
ctrl := gomock.NewController(t)
defer ctrl.Finish()
client := mock.NewMockNodeClient(ctrl)
bs := Service{
nodeClient: client,
}
wanted := &ethpb.Genesis{
GenesisValidatorsRoot: []byte("I am genesis"),
}
client.EXPECT().GetGenesis(gomock.Any(), gomock.Any()).Return(wanted, nil)
res, err := bs.GenesisValidatorsRoot(context.Background())
if err != nil {
t.Fatal(err)
}
if !bytes.Equal(res, wanted.GenesisValidatorsRoot) {
t.Errorf("Wanted %#x, received %#x", wanted.GenesisValidatorsRoot, res)
}
// test next fetch uses memory and not the rpc call.
res, err = bs.GenesisValidatorsRoot(context.Background())
if err != nil {
t.Fatal(err)
}
if !bytes.Equal(res, wanted.GenesisValidatorsRoot) {
t.Errorf("Wanted %#x, received %#x", wanted.GenesisValidatorsRoot, res)
}
}
func TestService_QuerySyncStatus(t *testing.T) {
hook := logTest.NewGlobal()
ctrl := gomock.NewController(t)
defer ctrl.Finish()
client := mock.NewMockNodeClient(ctrl)
bs := Service{
nodeClient: client,
}
syncStatusPollingInterval = time.Millisecond
client.EXPECT().GetSyncStatus(gomock.Any(), gomock.Any()).Return(&ethpb.SyncStatus{
Syncing: true,
}, nil)
client.EXPECT().GetSyncStatus(gomock.Any(), gomock.Any()).Return(&ethpb.SyncStatus{
Syncing: false,
}, nil)
bs.querySyncStatus(context.Background())
testutil.AssertLogsContain(t, hook, "Waiting for beacon node to be fully synced...")
testutil.AssertLogsContain(t, hook, "Beacon node is fully synced")
}