mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-08 02:31:19 +00:00
5a66807989
* First take at updating everything to v5 * Patch gRPC gateway to use prysm v5 Fix patch * Update go ssz --------- Co-authored-by: Preston Van Loon <pvanloon@offchainlabs.com>
92 lines
2.6 KiB
Go
92 lines
2.6 KiB
Go
package backfill
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/libp2p/go-libp2p/core/peer"
|
|
"github.com/prysmaticlabs/prysm/v5/beacon-chain/db/filesystem"
|
|
p2ptest "github.com/prysmaticlabs/prysm/v5/beacon-chain/p2p/testing"
|
|
"github.com/prysmaticlabs/prysm/v5/beacon-chain/startup"
|
|
"github.com/prysmaticlabs/prysm/v5/beacon-chain/sync"
|
|
"github.com/prysmaticlabs/prysm/v5/beacon-chain/verification"
|
|
"github.com/prysmaticlabs/prysm/v5/consensus-types/blocks"
|
|
"github.com/prysmaticlabs/prysm/v5/encoding/bytesutil"
|
|
"github.com/prysmaticlabs/prysm/v5/testing/require"
|
|
"github.com/prysmaticlabs/prysm/v5/testing/util"
|
|
)
|
|
|
|
type mockAssigner struct {
|
|
err error
|
|
assign []peer.ID
|
|
}
|
|
|
|
// Assign satisfies the PeerAssigner interface so that mockAssigner can be used in tests
|
|
// in place of the concrete p2p implementation of PeerAssigner.
|
|
func (m mockAssigner) Assign(busy map[peer.ID]bool, n int) ([]peer.ID, error) {
|
|
if m.err != nil {
|
|
return nil, m.err
|
|
}
|
|
return m.assign, nil
|
|
}
|
|
|
|
var _ PeerAssigner = &mockAssigner{}
|
|
|
|
func mockNewBlobVerifier(_ blocks.ROBlob, _ []verification.Requirement) verification.BlobVerifier {
|
|
return &verification.MockBlobVerifier{}
|
|
}
|
|
|
|
func TestPoolDetectAllEnded(t *testing.T) {
|
|
nw := 5
|
|
p2p := p2ptest.NewTestP2P(t)
|
|
ctx := context.Background()
|
|
ma := &mockAssigner{}
|
|
pool := newP2PBatchWorkerPool(p2p, nw)
|
|
st, err := util.NewBeaconState()
|
|
require.NoError(t, err)
|
|
keys, err := st.PublicKeys()
|
|
require.NoError(t, err)
|
|
v, err := newBackfillVerifier(st.GenesisValidatorsRoot(), keys)
|
|
require.NoError(t, err)
|
|
|
|
ctxMap, err := sync.ContextByteVersionsForValRoot(bytesutil.ToBytes32(st.GenesisValidatorsRoot()))
|
|
require.NoError(t, err)
|
|
bfs := filesystem.NewEphemeralBlobStorage(t)
|
|
pool.spawn(ctx, nw, startup.NewClock(time.Now(), [32]byte{}), ma, v, ctxMap, mockNewBlobVerifier, bfs)
|
|
br := batcher{min: 10, size: 10}
|
|
endSeq := br.before(0)
|
|
require.Equal(t, batchEndSequence, endSeq.state)
|
|
for i := 0; i < nw; i++ {
|
|
pool.todo(endSeq)
|
|
}
|
|
b, err := pool.complete()
|
|
require.ErrorIs(t, err, errEndSequence)
|
|
require.Equal(t, b.end, endSeq.end)
|
|
}
|
|
|
|
type mockPool struct {
|
|
spawnCalled []int
|
|
finishedChan chan batch
|
|
finishedErr chan error
|
|
todoChan chan batch
|
|
}
|
|
|
|
func (m *mockPool) spawn(_ context.Context, _ int, _ *startup.Clock, _ PeerAssigner, _ *verifier, _ sync.ContextByteVersions, _ verification.NewBlobVerifier, _ *filesystem.BlobStorage) {
|
|
}
|
|
|
|
func (m *mockPool) todo(b batch) {
|
|
m.todoChan <- b
|
|
}
|
|
|
|
func (m *mockPool) complete() (batch, error) {
|
|
select {
|
|
case b := <-m.finishedChan:
|
|
return b, nil
|
|
case err := <-m.finishedErr:
|
|
return batch{}, err
|
|
}
|
|
}
|
|
|
|
var _ batchWorkerPool = &mockPool{}
|