mirror of
https://github.com/OffchainLabs/prysm.git
synced 2026-01-09 15:37:56 -05:00
Update fastssz (#6760)
* Update fastssz * Merge branch 'master' of github.com:prysmaticlabs/prysm into update-fssz * fmt * gaz * Merge refs/heads/master into update-fssz * goimports * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Fix * fix ethereumapis * fix again * kafka * fix gen file * fix compute signing root * gofmt * checkpoint progress * progress * checkpoint * progress * Fix build * checkpoint * helpers * Another test fixed * gaz * another test fix * gofmt * some fixes * Merge branch 'master' of github.com:prysmaticlabs/prysm into update-fssz * fix one test * Merge branch 'master' of github.com:prysmaticlabs/prysm into update-fssz * fill empty checkpoint roots * more padding * more padding * Fix //beacon-chain/rpc/debug:go_default_test * fix //beacon-chain/core/state:go_default_test * fix //beacon-chain/core/state:go_default_test * fix some htr errors * fix //slasher/rpc:go_default_test * Progress on //beacon-chain/core/blocks:go_default_test * Progress on //beacon-chain/core/blocks:go_default_test * Progress on //beacon-chain/core/blocks:go_default_test * fix //slasher/db/kv:go_default_test * progress * fix //beacon-chain/sync/initial-sync:go_raceon_test * gofmt and gaz * fix one more test, taking a break * Fix //beacon-chain/core/blocks:go_default_test * Complete beacon-chain/powchain * Do most of beacon-chain/rpc/beacon/ * Do most of beacon-chain/blockchain * fix //beacon-chain/operations/attestations/kv:go_default_test * Fix //beacon-chain/cache/depositcache:go_default_test * Fix //slasher/detection:go_default_test * Progress * fix //beacon-chain/rpc/validator:go_default_test * gofmt * fix //validator/client:go_default_test * fix * fix //beacon-chain/blockchain:go_raceoff_test * fix //beacon-chain/rpc/beacon:go_default_test * fix 1 of 4 shards in //beacon-chain/sync:go_default_test * Fix //beacon-chain/sync:go_default_test and gofmt * prevent panic * fix //beacon-chain/state/stategen:go_default_test * fix * Merge branch 'master' of github.com:prysmaticlabs/prysm into update-fssz * fix most tests * Self review, go mod tidy, run regen scripts * fix slasher * Update ethereumapis * disable spawn strategy override * Merge refs/heads/master into update-fssz * Merge refs/heads/master into update-fssz * Remove extra line in imports * Remove extra line in imports * Gofmt * PR feedback from @nisdas
This commit is contained in:
@@ -11,7 +11,6 @@ import (
|
||||
"github.com/libp2p/go-libp2p-core/network"
|
||||
"github.com/libp2p/go-libp2p-core/protocol"
|
||||
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
||||
"github.com/prysmaticlabs/go-ssz"
|
||||
mock "github.com/prysmaticlabs/prysm/beacon-chain/blockchain/testing"
|
||||
dbtest "github.com/prysmaticlabs/prysm/beacon-chain/db/testing"
|
||||
"github.com/prysmaticlabs/prysm/beacon-chain/p2p/peers"
|
||||
@@ -46,17 +45,23 @@ func TestRegularSyncBeaconBlockSubscriber_ProcessPendingBlocks1(t *testing.T) {
|
||||
err := r.initCaches()
|
||||
require.NoError(t, err)
|
||||
|
||||
b0 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{}}
|
||||
b0 := testutil.NewBeaconBlock()
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b0))
|
||||
b0Root, err := stateutil.BlockRoot(b0.Block)
|
||||
require.NoError(t, err)
|
||||
b3 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{Slot: 3, ParentRoot: b0Root[:]}}
|
||||
b3 := testutil.NewBeaconBlock()
|
||||
b3.Block.Slot = 3
|
||||
b3.Block.ParentRoot = b0Root[:]
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b3))
|
||||
// Incomplete block link
|
||||
b1 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{Slot: 1, ParentRoot: b0Root[:]}}
|
||||
b1 := testutil.NewBeaconBlock()
|
||||
b1.Block.Slot = 1
|
||||
b1.Block.ParentRoot = b0Root[:]
|
||||
b1Root, err := stateutil.BlockRoot(b1.Block)
|
||||
require.NoError(t, err)
|
||||
b2 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{Slot: 2, ParentRoot: b1Root[:]}}
|
||||
b2 := testutil.NewBeaconBlock()
|
||||
b2.Block.Slot = 2
|
||||
b2.Block.ParentRoot = b1Root[:]
|
||||
b2Root, err := stateutil.BlockRoot(b1.Block)
|
||||
require.NoError(t, err)
|
||||
|
||||
@@ -89,6 +94,7 @@ func TestRegularSync_InsertDuplicateBlocks(t *testing.T) {
|
||||
chain: &mock.ChainService{
|
||||
FinalizedCheckPoint: ðpb.Checkpoint{
|
||||
Epoch: 0,
|
||||
Root: make([]byte, 32),
|
||||
},
|
||||
},
|
||||
slotToPendingBlocks: make(map[uint64][]*ethpb.SignedBeaconBlock),
|
||||
@@ -97,11 +103,13 @@ func TestRegularSync_InsertDuplicateBlocks(t *testing.T) {
|
||||
err := r.initCaches()
|
||||
require.NoError(t, err)
|
||||
|
||||
b0 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{}}
|
||||
b0 := testutil.NewBeaconBlock()
|
||||
b0r := [32]byte{'a'}
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b0))
|
||||
b0Root, err := stateutil.BlockRoot(b0.Block)
|
||||
b1 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{Slot: 1, ParentRoot: b0Root[:]}}
|
||||
b1 := testutil.NewBeaconBlock()
|
||||
b1.Block.Slot = 1
|
||||
b1.Block.ParentRoot = b0Root[:]
|
||||
b1r := [32]byte{'b'}
|
||||
|
||||
r.insertBlockToPendingQueue(b0.Block.Slot, b0, b0r)
|
||||
@@ -124,7 +132,7 @@ func TestRegularSync_InsertDuplicateBlocks(t *testing.T) {
|
||||
// b0
|
||||
// \- b3 - b4
|
||||
// Test b2 and b3 were missed, after receiving them we can process 2 chains.
|
||||
func TestRegularSyncBeaconBlockSubscriber_ProcessPendingBlocks2(t *testing.T) {
|
||||
func TestRegularSyncBeaconBlockSubscriber_ProcessPendingBlocks_2Chains(t *testing.T) {
|
||||
db, _ := dbtest.SetupDB(t)
|
||||
p1 := p2ptest.NewTestP2P(t)
|
||||
p2 := p2ptest.NewTestP2P(t)
|
||||
@@ -152,6 +160,7 @@ func TestRegularSyncBeaconBlockSubscriber_ProcessPendingBlocks2(t *testing.T) {
|
||||
chain: &mock.ChainService{
|
||||
FinalizedCheckPoint: ðpb.Checkpoint{
|
||||
Epoch: 0,
|
||||
Root: make([]byte, 32),
|
||||
},
|
||||
},
|
||||
slotToPendingBlocks: make(map[uint64][]*ethpb.SignedBeaconBlock),
|
||||
@@ -163,47 +172,57 @@ func TestRegularSyncBeaconBlockSubscriber_ProcessPendingBlocks2(t *testing.T) {
|
||||
p1.Peers().SetConnectionState(p2.PeerID(), peers.PeerConnected)
|
||||
p1.Peers().SetChainState(p2.PeerID(), &pb.Status{})
|
||||
|
||||
b0 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{}}
|
||||
b0 := testutil.NewBeaconBlock()
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b0))
|
||||
b0Root, err := stateutil.BlockRoot(b0.Block)
|
||||
require.NoError(t, err)
|
||||
b1 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{Slot: 1, ParentRoot: b0Root[:]}}
|
||||
b1 := testutil.NewBeaconBlock()
|
||||
b1.Block.Slot = 1
|
||||
b1.Block.ParentRoot = b0Root[:]
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b1))
|
||||
b1Root, err := stateutil.BlockRoot(b1.Block)
|
||||
require.NoError(t, err)
|
||||
|
||||
// Incomplete block links
|
||||
b2 := ðpb.BeaconBlock{Slot: 2, ParentRoot: b1Root[:]}
|
||||
b2Root, err := ssz.HashTreeRoot(b2)
|
||||
b2 := testutil.NewBeaconBlock()
|
||||
b2.Block.Slot = 2
|
||||
b2.Block.ParentRoot = b1Root[:]
|
||||
b2Root, err := b2.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
b5 := ðpb.BeaconBlock{Slot: 5, ParentRoot: b2Root[:]}
|
||||
b5Root, err := ssz.HashTreeRoot(b5)
|
||||
b5 := testutil.NewBeaconBlock()
|
||||
b5.Block.Slot = 5
|
||||
b5.Block.ParentRoot = b2Root[:]
|
||||
b5Root, err := b5.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
b3 := ðpb.BeaconBlock{Slot: 3, ParentRoot: b0Root[:]}
|
||||
b3Root, err := ssz.HashTreeRoot(b3)
|
||||
b3 := testutil.NewBeaconBlock()
|
||||
b3.Block.Slot = 3
|
||||
b3.Block.ParentRoot = b0Root[:]
|
||||
b3Root, err := b3.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
b4 := ðpb.BeaconBlock{Slot: 4, ParentRoot: b3Root[:]}
|
||||
b4Root, err := ssz.HashTreeRoot(b4)
|
||||
b4 := testutil.NewBeaconBlock()
|
||||
b4.Block.Slot = 4
|
||||
b4.Block.ParentRoot = b3Root[:]
|
||||
b4Root, err := b4.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
|
||||
r.insertBlockToPendingQueue(b4.Slot, ðpb.SignedBeaconBlock{Block: b4}, b4Root)
|
||||
r.insertBlockToPendingQueue(b5.Slot, ðpb.SignedBeaconBlock{Block: b5}, b5Root)
|
||||
r.insertBlockToPendingQueue(b4.Block.Slot, b4, b4Root)
|
||||
r.insertBlockToPendingQueue(b5.Block.Slot, b5, b5Root)
|
||||
|
||||
require.NoError(t, r.processPendingBlocks(context.Background()))
|
||||
assert.Equal(t, 2, len(r.slotToPendingBlocks), "Incorrect size for slot to pending blocks cache")
|
||||
assert.Equal(t, 2, len(r.seenPendingBlocks), "Incorrect size for seen pending block")
|
||||
|
||||
// Add b3 to the cache
|
||||
r.insertBlockToPendingQueue(b3.Slot, ðpb.SignedBeaconBlock{Block: b3}, b3Root)
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), ðpb.SignedBeaconBlock{Block: b3}))
|
||||
r.insertBlockToPendingQueue(b3.Block.Slot, b3, b3Root)
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b3))
|
||||
require.NoError(t, r.processPendingBlocks(context.Background()))
|
||||
assert.Equal(t, 1, len(r.slotToPendingBlocks), "Incorrect size for slot to pending blocks cache")
|
||||
assert.Equal(t, 3, len(r.seenPendingBlocks), "Incorrect size for seen pending block")
|
||||
|
||||
// Add b2 to the cache
|
||||
r.insertBlockToPendingQueue(b2.Slot, ðpb.SignedBeaconBlock{Block: b2}, b2Root)
|
||||
r.insertBlockToPendingQueue(b2.Block.Slot, b2, b2Root)
|
||||
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), ðpb.SignedBeaconBlock{Block: b2}))
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b2))
|
||||
require.NoError(t, r.processPendingBlocks(context.Background()))
|
||||
assert.Equal(t, 0, len(r.slotToPendingBlocks), "Incorrect size for slot to pending blocks cache")
|
||||
assert.Equal(t, 4, len(r.seenPendingBlocks), "Incorrect size for seen pending block")
|
||||
@@ -222,6 +241,7 @@ func TestRegularSyncBeaconBlockSubscriber_PruneOldPendingBlocks(t *testing.T) {
|
||||
chain: &mock.ChainService{
|
||||
FinalizedCheckPoint: ðpb.Checkpoint{
|
||||
Epoch: 1,
|
||||
Root: make([]byte, 32),
|
||||
},
|
||||
},
|
||||
slotToPendingBlocks: make(map[uint64][]*ethpb.SignedBeaconBlock),
|
||||
@@ -233,33 +253,43 @@ func TestRegularSyncBeaconBlockSubscriber_PruneOldPendingBlocks(t *testing.T) {
|
||||
p1.Peers().SetConnectionState(p1.PeerID(), peers.PeerConnected)
|
||||
p1.Peers().SetChainState(p1.PeerID(), &pb.Status{})
|
||||
|
||||
b0 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{}}
|
||||
b0 := testutil.NewBeaconBlock()
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b0))
|
||||
b0Root, err := stateutil.BlockRoot(b0.Block)
|
||||
require.NoError(t, err)
|
||||
b1 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{Slot: 1, ParentRoot: b0Root[:]}}
|
||||
b1 := testutil.NewBeaconBlock()
|
||||
b1.Block.Slot = 1
|
||||
b1.Block.ParentRoot = b0Root[:]
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b1))
|
||||
b1Root, err := stateutil.BlockRoot(b1.Block)
|
||||
require.NoError(t, err)
|
||||
|
||||
// Incomplete block links
|
||||
b2 := ðpb.BeaconBlock{Slot: 2, ParentRoot: b1Root[:]}
|
||||
b2Root, err := ssz.HashTreeRoot(b2)
|
||||
b2 := testutil.NewBeaconBlock()
|
||||
b2.Block.Slot = 2
|
||||
b2.Block.ParentRoot = b1Root[:]
|
||||
b2Root, err := b2.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
b5 := ðpb.BeaconBlock{Slot: 5, ParentRoot: b2Root[:]}
|
||||
b5Root, err := ssz.HashTreeRoot(b5)
|
||||
b5 := testutil.NewBeaconBlock()
|
||||
b5.Block.Slot = 5
|
||||
b5.Block.ParentRoot = b2Root[:]
|
||||
b5Root, err := b5.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
b3 := ðpb.BeaconBlock{Slot: 3, ParentRoot: b0Root[:]}
|
||||
b3Root, err := ssz.HashTreeRoot(b3)
|
||||
b3 := testutil.NewBeaconBlock()
|
||||
b3.Block.Slot = 3
|
||||
b3.Block.ParentRoot = b0Root[:]
|
||||
b3Root, err := b3.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
b4 := ðpb.BeaconBlock{Slot: 4, ParentRoot: b3Root[:]}
|
||||
b4Root, err := ssz.HashTreeRoot(b4)
|
||||
b4 := testutil.NewBeaconBlock()
|
||||
b4.Block.Slot = 4
|
||||
b4.Block.ParentRoot = b3Root[:]
|
||||
b4Root, err := b4.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
|
||||
r.insertBlockToPendingQueue(b2.Slot, ðpb.SignedBeaconBlock{Block: b2}, b2Root)
|
||||
r.insertBlockToPendingQueue(b3.Slot, ðpb.SignedBeaconBlock{Block: b3}, b3Root)
|
||||
r.insertBlockToPendingQueue(b4.Slot, ðpb.SignedBeaconBlock{Block: b4}, b4Root)
|
||||
r.insertBlockToPendingQueue(b5.Slot, ðpb.SignedBeaconBlock{Block: b5}, b5Root)
|
||||
r.insertBlockToPendingQueue(b2.Block.Slot, b2, b2Root)
|
||||
r.insertBlockToPendingQueue(b3.Block.Slot, b3, b3Root)
|
||||
r.insertBlockToPendingQueue(b4.Block.Slot, b4, b4Root)
|
||||
r.insertBlockToPendingQueue(b5.Block.Slot, b5, b5Root)
|
||||
|
||||
require.NoError(t, r.processPendingBlocks(context.Background()))
|
||||
assert.Equal(t, 0, len(r.slotToPendingBlocks), "Incorrect size for slot to pending blocks cache")
|
||||
@@ -295,6 +325,7 @@ func TestService_BatchRootRequest(t *testing.T) {
|
||||
chain: &mock.ChainService{
|
||||
FinalizedCheckPoint: ðpb.Checkpoint{
|
||||
Epoch: 1,
|
||||
Root: make([]byte, 32),
|
||||
},
|
||||
},
|
||||
slotToPendingBlocks: make(map[uint64][]*ethpb.SignedBeaconBlock),
|
||||
@@ -307,26 +338,36 @@ func TestService_BatchRootRequest(t *testing.T) {
|
||||
p1.Peers().SetConnectionState(p2.PeerID(), peers.PeerConnected)
|
||||
p1.Peers().SetChainState(p2.PeerID(), &pb.Status{FinalizedEpoch: 2})
|
||||
|
||||
b0 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{}}
|
||||
b0 := testutil.NewBeaconBlock()
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b0))
|
||||
b0Root, err := stateutil.BlockRoot(b0.Block)
|
||||
require.NoError(t, err)
|
||||
b1 := ðpb.SignedBeaconBlock{Block: ðpb.BeaconBlock{Slot: 1, ParentRoot: b0Root[:]}}
|
||||
b1 := testutil.NewBeaconBlock()
|
||||
b1.Block.Slot = 1
|
||||
b1.Block.ParentRoot = b0Root[:]
|
||||
require.NoError(t, r.db.SaveBlock(context.Background(), b1))
|
||||
b1Root, err := stateutil.BlockRoot(b1.Block)
|
||||
require.NoError(t, err)
|
||||
|
||||
b2 := ðpb.BeaconBlock{Slot: 2, ParentRoot: b1Root[:]}
|
||||
b2Root, err := ssz.HashTreeRoot(b2)
|
||||
b2 := testutil.NewBeaconBlock()
|
||||
b2.Block.Slot = 2
|
||||
b2.Block.ParentRoot = b1Root[:]
|
||||
b2Root, err := b2.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
b5 := ðpb.BeaconBlock{Slot: 5, ParentRoot: b2Root[:]}
|
||||
b5Root, err := ssz.HashTreeRoot(b5)
|
||||
b5 := testutil.NewBeaconBlock()
|
||||
b5.Block.Slot = 5
|
||||
b5.Block.ParentRoot = b2Root[:]
|
||||
b5Root, err := b5.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
b3 := ðpb.BeaconBlock{Slot: 3, ParentRoot: b0Root[:]}
|
||||
b3Root, err := ssz.HashTreeRoot(b3)
|
||||
b3 := testutil.NewBeaconBlock()
|
||||
b3.Block.Slot = 3
|
||||
b3.Block.ParentRoot = b0Root[:]
|
||||
b3Root, err := b3.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
b4 := ðpb.BeaconBlock{Slot: 4, ParentRoot: b3Root[:]}
|
||||
b4Root, err := ssz.HashTreeRoot(b4)
|
||||
b4 := testutil.NewBeaconBlock()
|
||||
b4.Block.Slot = 4
|
||||
b4.Block.ParentRoot = b3Root[:]
|
||||
b4Root, err := b4.Block.HashTreeRoot()
|
||||
require.NoError(t, err)
|
||||
|
||||
// Send in duplicated roots to also test deduplicaton.
|
||||
@@ -341,8 +382,7 @@ func TestService_BatchRootRequest(t *testing.T) {
|
||||
out := [][32]byte{}
|
||||
assert.NoError(t, p2.Encoding().DecodeWithMaxLength(stream, &out))
|
||||
assert.DeepEqual(t, expectedRoots, out, "Did not receive expected message")
|
||||
response := []*ethpb.SignedBeaconBlock{{Block: b2},
|
||||
{Block: b3}, {Block: b4}, {Block: b5}}
|
||||
response := []*ethpb.SignedBeaconBlock{b2, b3, b4, b5}
|
||||
for _, blk := range response {
|
||||
_, err := stream.Write([]byte{responseCodeSuccess})
|
||||
assert.NoError(t, err, "Failed to write to stream")
|
||||
|
||||
Reference in New Issue
Block a user