mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-04 00:44:27 +00:00
0326be86b5
* starting on patch * finish determining all required patches * properly redefine the patch rules * new patch * rem double semicolon * fix patch file * Merge branch 'master' of github.com:prysmaticlabs/prysm into deprecate-eth-protos * building the deps * test target passes using ethereumapis * compile gateway * attempting to build everything * e2e use ethereumapis * more fixes for slasher * other item * getting closer to compiling slasher * build slasher package * Merge branch 'master' into deprecate-eth-protos * Merge branch 'master' into deprecate-eth-protos * fix benches * lint gazelle * Merge branch 'deprecate-eth-protos' of github.com:prysmaticlabs/prysm into deprecate-eth-protos * proper gateway * lint * Merge branch 'master' into deprecate-eth-protos * fix build * Merge branch 'deprecate-eth-protos' of github.com:prysmaticlabs/prysm into deprecate-eth-protos * use swag * resolve * ignore change * include new patch changes * fix test * builds * fix e2e * gaz
169 lines
4.1 KiB
Go
169 lines
4.1 KiB
Go
package forkchoice
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/cache"
|
|
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}
|
|
|
|
if err := store.GenesisStore(ctx, ðpb.Checkpoint{}, ðpb.Checkpoint{}); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
store.justifiedCheckpt.Root = roots[0]
|
|
if err := store.db.SaveState(ctx, s, bytesutil.ToBytes32(roots[0])); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
if err := store.checkpointState.AddCheckpointState(&cache.CheckpointState{
|
|
Checkpoint: store.justifiedCheckpt,
|
|
State: s,
|
|
}); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
// Spread out the votes evenly for all 3 leaf nodes
|
|
for i := 0; i < len(validators); i++ {
|
|
switch {
|
|
case i < 256:
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[1]}
|
|
case i > 768:
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[7]}
|
|
default:
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[8]}
|
|
}
|
|
}
|
|
|
|
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}
|
|
if err := store.GenesisStore(ctx, ðpb.Checkpoint{}, ðpb.Checkpoint{}); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
store.justifiedCheckpt.Root = roots[0]
|
|
if err := store.db.SaveState(ctx, s, bytesutil.ToBytes32(roots[0])); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
if err := store.checkpointState.AddCheckpointState(&cache.CheckpointState{
|
|
Checkpoint: store.justifiedCheckpt,
|
|
State: s,
|
|
}); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
// Spread out the votes evenly for all the leaf nodes. 8 to 15
|
|
nodeIndex := 8
|
|
for i := 0; i < len(validators); i++ {
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[nodeIndex]}
|
|
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}
|
|
if err := store.GenesisStore(ctx, ðpb.Checkpoint{}, ðpb.Checkpoint{}); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
store.justifiedCheckpt.Root = roots[0]
|
|
if err := store.db.SaveState(ctx, s, bytesutil.ToBytes32(roots[0])); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
if err := store.checkpointState.AddCheckpointState(&cache.CheckpointState{
|
|
Checkpoint: store.justifiedCheckpt,
|
|
State: s,
|
|
}); err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
|
|
// All validators vote on the same head
|
|
for i := 0; i < len(validators); i++ {
|
|
store.latestVoteMap[uint64(i)] = &pb.ValidatorLatestVote{Root: roots[len(roots)-1]}
|
|
}
|
|
|
|
b.ResetTimer()
|
|
for i := 0; i < b.N; i++ {
|
|
_, err := store.Head(ctx)
|
|
if err != nil {
|
|
b.Fatal(err)
|
|
}
|
|
}
|
|
}
|