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, []byte{'g'}) 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) } } }