2019-02-10 21:07:31 +00:00
|
|
|
package sync
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2019-02-20 05:07:28 +00:00
|
|
|
"crypto/rand"
|
2019-02-10 21:07:31 +00:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2019-02-20 05:07:28 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/helpers"
|
2019-02-10 21:07:31 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/db"
|
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/internal"
|
2019-02-20 05:07:28 +00:00
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/bls"
|
2019-04-08 02:46:55 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/featureconfig"
|
2019-02-23 06:06:20 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
2019-02-10 21:07:31 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func NotSyncQuerierConfig() *QuerierConfig {
|
|
|
|
return &QuerierConfig{
|
|
|
|
ResponseBufferSize: 100,
|
2019-02-23 06:06:20 +00:00
|
|
|
CurrentHeadSlot: 10,
|
2019-02-10 21:07:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-08 02:46:55 +00:00
|
|
|
func init() {
|
|
|
|
featureconfig.InitFeatureConfig(&featureconfig.FeatureFlagConfig{})
|
|
|
|
}
|
|
|
|
|
2019-02-10 21:07:31 +00:00
|
|
|
func initializeTestSyncService(ctx context.Context, cfg *Config, synced bool) *Service {
|
|
|
|
var sqCfg *QuerierConfig
|
|
|
|
if synced {
|
|
|
|
sqCfg = DefaultQuerierConfig()
|
|
|
|
} else {
|
|
|
|
sqCfg = NotSyncQuerierConfig()
|
|
|
|
}
|
|
|
|
|
2019-02-23 06:06:20 +00:00
|
|
|
services := NewSyncService(ctx, cfg)
|
2019-02-10 21:07:31 +00:00
|
|
|
|
2019-02-23 06:06:20 +00:00
|
|
|
sqCfg.BeaconDB = cfg.BeaconDB
|
|
|
|
sqCfg.P2P = cfg.P2P
|
2019-02-10 21:07:31 +00:00
|
|
|
sq := NewQuerierService(ctx, sqCfg)
|
|
|
|
|
2019-02-23 06:06:20 +00:00
|
|
|
services.Querier = sq
|
2019-02-10 21:07:31 +00:00
|
|
|
|
2019-02-23 06:06:20 +00:00
|
|
|
return services
|
2019-02-20 05:07:28 +00:00
|
|
|
}
|
2019-02-10 21:07:31 +00:00
|
|
|
|
2019-04-26 06:24:01 +00:00
|
|
|
func setupInitialDeposits(t *testing.T) ([]*pb.Deposit, []*bls.SecretKey) {
|
|
|
|
numOfDeposits := 10
|
|
|
|
privKeys := make([]*bls.SecretKey, numOfDeposits)
|
|
|
|
deposits := make([]*pb.Deposit, numOfDeposits)
|
2019-02-20 05:07:28 +00:00
|
|
|
for i := 0; i < len(deposits); i++ {
|
|
|
|
priv, err := bls.RandKey(rand.Reader)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
depositInput := &pb.DepositInput{
|
|
|
|
Pubkey: priv.PublicKey().Marshal(),
|
|
|
|
}
|
|
|
|
balance := params.BeaconConfig().MaxDepositAmount
|
|
|
|
depositData, err := helpers.EncodeDepositData(depositInput, balance, time.Now().Unix())
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Cannot encode data: %v", err)
|
|
|
|
}
|
|
|
|
deposits[i] = &pb.Deposit{DepositData: depositData}
|
|
|
|
privKeys[i] = priv
|
|
|
|
}
|
|
|
|
return deposits, privKeys
|
2019-02-10 21:07:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func setupTestSyncService(t *testing.T, synced bool) (*Service, *db.BeaconDB) {
|
|
|
|
db := internal.SetupDB(t)
|
|
|
|
|
|
|
|
unixTime := uint64(time.Now().Unix())
|
2019-04-26 06:24:01 +00:00
|
|
|
deposits, _ := setupInitialDeposits(t)
|
2019-04-09 19:06:23 +00:00
|
|
|
if err := db.InitializeState(context.Background(), unixTime, deposits, &pb.Eth1Data{}); err != nil {
|
2019-02-10 21:07:31 +00:00
|
|
|
t.Fatalf("Failed to initialize state: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg := &Config{
|
2019-03-27 19:53:43 +00:00
|
|
|
ChainService: &mockChainService{
|
2019-03-27 18:47:05 +00:00
|
|
|
db: db,
|
|
|
|
},
|
2019-02-10 21:07:31 +00:00
|
|
|
P2P: &mockP2P{},
|
|
|
|
BeaconDB: db,
|
|
|
|
OperationService: &mockOperationService{},
|
|
|
|
}
|
|
|
|
service := initializeTestSyncService(context.Background(), cfg, synced)
|
|
|
|
return service, db
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-02-22 15:11:26 +00:00
|
|
|
func TestStatus_NotSynced(t *testing.T) {
|
2019-02-10 21:07:31 +00:00
|
|
|
serviceNotSynced, db := setupTestSyncService(t, false)
|
|
|
|
defer internal.TeardownDB(t, db)
|
2019-05-09 21:02:24 +00:00
|
|
|
synced := serviceNotSynced.InitialSync.NodeIsSynced()
|
2019-04-05 21:06:04 +00:00
|
|
|
if synced {
|
|
|
|
t.Error("Wanted false, but got true")
|
2019-02-10 21:07:31 +00:00
|
|
|
}
|
|
|
|
}
|