mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2024-12-25 12:57:18 +00:00
4b6441f626
* Update pending blks queue to ttl one * Update tests * Comment * Gazelle * Fix fuzz * More comments * Fix fuxx import * Nishant's feedback * Happy lint * Return error for len(blks) >= maxBlocksPerSlot * Ensure proposer time conv * don't use gcache's default exp time it's 0 * fix TestService_AddPeningBlockToQueueOverMax * Update beacon-chain/sync/pending_blocks_queue.go Co-authored-by: Nishant Das <nishdas93@gmail.com> * Fix time conversion Co-authored-by: Nishant Das <nishdas93@gmail.com>
57 lines
1.8 KiB
Go
57 lines
1.8 KiB
Go
// +build libfuzzer
|
|
|
|
package sync
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/gogo/protobuf/proto"
|
|
"github.com/libp2p/go-libp2p-core/peer"
|
|
pubsub "github.com/libp2p/go-libp2p-pubsub"
|
|
gcache "github.com/patrickmn/go-cache"
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
)
|
|
|
|
// NewRegularSyncFuzz service without registering handlers.
|
|
func NewRegularSyncFuzz(cfg *Config) *Service {
|
|
rLimiter := newRateLimiter(cfg.P2P)
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
r := &Service{
|
|
ctx: ctx,
|
|
cancel: cancel,
|
|
db: cfg.DB,
|
|
p2p: cfg.P2P,
|
|
attPool: cfg.AttPool,
|
|
exitPool: cfg.ExitPool,
|
|
slashingPool: cfg.SlashingPool,
|
|
chain: cfg.Chain,
|
|
initialSync: cfg.InitialSync,
|
|
attestationNotifier: cfg.AttestationNotifier,
|
|
slotToPendingBlocks: gcache.New(time.Second, 2*time.Second),
|
|
seenPendingBlocks: make(map[[32]byte]bool),
|
|
blkRootToPendingAtts: make(map[[32]byte][]*ethpb.SignedAggregateAttestationAndProof),
|
|
stateNotifier: cfg.StateNotifier,
|
|
blockNotifier: cfg.BlockNotifier,
|
|
stateSummaryCache: cfg.StateSummaryCache,
|
|
stateGen: cfg.StateGen,
|
|
rateLimiter: rLimiter,
|
|
}
|
|
|
|
return r
|
|
}
|
|
|
|
// FuzzValidateBeaconBlockPubSub exports private method validateBeaconBlockPubSub for fuzz testing.
|
|
func (s *Service) FuzzValidateBeaconBlockPubSub(ctx context.Context, pid peer.ID, msg *pubsub.Message) pubsub.ValidationResult {
|
|
return s.validateBeaconBlockPubSub(ctx, pid, msg)
|
|
}
|
|
|
|
// FuzzBeaconBlockSubscriber exports private method beaconBlockSubscriber for fuzz testing.
|
|
func (s *Service) FuzzBeaconBlockSubscriber(ctx context.Context, msg proto.Message) error {
|
|
return s.beaconBlockSubscriber(ctx, msg)
|
|
}
|
|
|
|
func (s *Service) InitCaches() error {
|
|
return s.initCaches()
|
|
}
|