2019-08-20 22:13:20 +00:00
|
|
|
package forkchoice
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
2019-11-27 05:08:18 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
2019-08-27 22:01:27 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/cache"
|
2019-08-20 22:13:20 +00:00
|
|
|
testDB "github.com/prysmaticlabs/prysm/beacon-chain/db/testing"
|
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
|
|
|
)
|
|
|
|
|
|
|
|
func BenchmarkForkChoiceTree1(b *testing.B) {
|
|
|
|
ctx := context.Background()
|
|
|
|
db := testDB.SetupDB(b)
|
|
|
|
defer testDB.TeardownDB(b, db)
|
|
|
|
|
|
|
|
store := NewForkChoiceService(ctx, db)
|
|
|
|
|
|
|
|
roots, err := blockTree1(db)
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Benchmark fork choice with 1024 validators
|
|
|
|
validators := make([]*ethpb.Validator, 1024)
|
|
|
|
for i := 0; i < len(validators); i++ {
|
|
|
|
validators[i] = ðpb.Validator{ExitEpoch: 2, EffectiveBalance: 1e9}
|
|
|
|
}
|
|
|
|
s := &pb.BeaconState{Validators: validators}
|
2019-08-30 13:58:02 +00:00
|
|
|
|
|
|
|
if err := store.GenesisStore(ctx, ðpb.Checkpoint{}, ðpb.Checkpoint{}); err != nil {
|
2019-08-20 22:13:20 +00:00
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
store.justifiedCheckpt.Root = roots[0]
|
|
|
|
if err := store.db.SaveState(ctx, s, bytesutil.ToBytes32(roots[0])); err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2019-08-27 22:01:27 +00:00
|
|
|
if err := store.checkpointState.AddCheckpointState(&cache.CheckpointState{
|
|
|
|
Checkpoint: store.justifiedCheckpt,
|
|
|
|
State: s,
|
|
|
|
}); err != nil {
|
|
|
|
b.Fatal(err)
|
2019-08-20 22:13:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Spread out the votes evenly for all 3 leaf nodes
|
|
|
|
for i := 0; i < len(validators); i++ {
|
|
|
|
switch {
|
|
|
|
case i < 256:
|
2019-11-25 16:34:20 +00:00
|
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[1]}
|
2019-08-20 22:13:20 +00:00
|
|
|
case i > 768:
|
2019-11-25 16:34:20 +00:00
|
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[7]}
|
2019-08-20 22:13:20 +00:00
|
|
|
default:
|
2019-11-25 16:34:20 +00:00
|
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[8]}
|
2019-08-20 22:13:20 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
b.ResetTimer()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
_, err := store.Head(ctx)
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkForkChoiceTree2(b *testing.B) {
|
|
|
|
ctx := context.Background()
|
|
|
|
db := testDB.SetupDB(b)
|
|
|
|
defer testDB.TeardownDB(b, db)
|
|
|
|
|
|
|
|
store := NewForkChoiceService(ctx, db)
|
|
|
|
|
|
|
|
roots, err := blockTree2(db)
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Benchmark fork choice with 1024 validators
|
|
|
|
validators := make([]*ethpb.Validator, 1024)
|
|
|
|
for i := 0; i < len(validators); i++ {
|
|
|
|
validators[i] = ðpb.Validator{ExitEpoch: 2, EffectiveBalance: 1e9}
|
|
|
|
}
|
|
|
|
s := &pb.BeaconState{Validators: validators}
|
2019-08-30 13:58:02 +00:00
|
|
|
if err := store.GenesisStore(ctx, ðpb.Checkpoint{}, ðpb.Checkpoint{}); err != nil {
|
2019-08-20 22:13:20 +00:00
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
store.justifiedCheckpt.Root = roots[0]
|
|
|
|
if err := store.db.SaveState(ctx, s, bytesutil.ToBytes32(roots[0])); err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2019-08-27 22:01:27 +00:00
|
|
|
if err := store.checkpointState.AddCheckpointState(&cache.CheckpointState{
|
|
|
|
Checkpoint: store.justifiedCheckpt,
|
|
|
|
State: s,
|
|
|
|
}); err != nil {
|
|
|
|
b.Fatal(err)
|
2019-08-20 22:13:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Spread out the votes evenly for all the leaf nodes. 8 to 15
|
|
|
|
nodeIndex := 8
|
|
|
|
for i := 0; i < len(validators); i++ {
|
2019-11-25 16:34:20 +00:00
|
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[nodeIndex]}
|
2019-08-20 22:13:20 +00:00
|
|
|
if i%155 == 0 {
|
|
|
|
nodeIndex++
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
b.ResetTimer()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
_, err := store.Head(ctx)
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkForkChoiceTree3(b *testing.B) {
|
|
|
|
ctx := context.Background()
|
|
|
|
db := testDB.SetupDB(b)
|
|
|
|
defer testDB.TeardownDB(b, db)
|
|
|
|
|
|
|
|
store := NewForkChoiceService(ctx, db)
|
|
|
|
|
|
|
|
roots, err := blockTree3(db)
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Benchmark fork choice with 1024 validators
|
|
|
|
validators := make([]*ethpb.Validator, 1024)
|
|
|
|
for i := 0; i < len(validators); i++ {
|
|
|
|
validators[i] = ðpb.Validator{ExitEpoch: 2, EffectiveBalance: 1e9}
|
|
|
|
}
|
|
|
|
s := &pb.BeaconState{Validators: validators}
|
2019-08-30 13:58:02 +00:00
|
|
|
if err := store.GenesisStore(ctx, ðpb.Checkpoint{}, ðpb.Checkpoint{}); err != nil {
|
2019-08-20 22:13:20 +00:00
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
store.justifiedCheckpt.Root = roots[0]
|
|
|
|
if err := store.db.SaveState(ctx, s, bytesutil.ToBytes32(roots[0])); err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2019-08-27 22:01:27 +00:00
|
|
|
if err := store.checkpointState.AddCheckpointState(&cache.CheckpointState{
|
|
|
|
Checkpoint: store.justifiedCheckpt,
|
|
|
|
State: s,
|
|
|
|
}); err != nil {
|
|
|
|
b.Fatal(err)
|
2019-08-20 22:13:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// All validators vote on the same head
|
|
|
|
for i := 0; i < len(validators); i++ {
|
2019-11-25 16:34:20 +00:00
|
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[len(roots)-1]}
|
2019-08-20 22:13:20 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
b.ResetTimer()
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
_, err := store.Head(ctx)
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|