2020-02-19 22:26:14 +00:00
|
|
|
package beaconclient
|
|
|
|
|
|
|
|
import (
|
2020-05-05 05:15:32 +00:00
|
|
|
"bytes"
|
2020-02-19 22:26:14 +00:00
|
|
|
"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 := ðpb.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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-05 05:15:32 +00:00
|
|
|
func TestService_GenesisValidatorsRoot(t *testing.T) {
|
|
|
|
ctrl := gomock.NewController(t)
|
|
|
|
defer ctrl.Finish()
|
|
|
|
|
|
|
|
client := mock.NewMockNodeClient(ctrl)
|
|
|
|
bs := Service{
|
|
|
|
nodeClient: client,
|
|
|
|
}
|
|
|
|
wanted := ðpb.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)
|
|
|
|
}
|
2020-05-08 05:51:56 +00:00
|
|
|
// 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)
|
|
|
|
}
|
2020-05-05 05:15:32 +00:00
|
|
|
}
|
|
|
|
|
2020-02-19 22:26:14 +00:00
|
|
|
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(ðpb.SyncStatus{
|
|
|
|
Syncing: true,
|
|
|
|
}, nil)
|
|
|
|
client.EXPECT().GetSyncStatus(gomock.Any(), gomock.Any()).Return(ðpb.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")
|
|
|
|
}
|