mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-10 03:31:20 +00:00
91 lines
2.6 KiB
Go
91 lines
2.6 KiB
Go
package fuzz
|
|
|
|
import (
|
|
"context"
|
|
"strings"
|
|
|
|
"github.com/libp2p/go-libp2p"
|
|
"github.com/libp2p/go-libp2p-core/host"
|
|
"github.com/libp2p/go-libp2p-core/peer"
|
|
"github.com/pkg/errors"
|
|
mock "github.com/prysmaticlabs/prysm/beacon-chain/blockchain/testing"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/p2p"
|
|
regularsync "github.com/prysmaticlabs/prysm/beacon-chain/sync"
|
|
mockSync "github.com/prysmaticlabs/prysm/beacon-chain/sync/initial-sync/testing"
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
ethpb "github.com/prysmaticlabs/prysm/proto/eth/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
var p *p2p.Service
|
|
var h host.Host
|
|
|
|
func init() {
|
|
logrus.SetLevel(logrus.PanicLevel)
|
|
|
|
var err error
|
|
p, err = p2p.NewService(context.Background(), &p2p.Config{
|
|
NoDiscovery: true,
|
|
})
|
|
if err != nil {
|
|
panic(errors.Wrap(err, "could not create new p2p service"))
|
|
}
|
|
|
|
h, err = libp2p.New(context.Background())
|
|
if err != nil {
|
|
panic(errors.Wrap(err, "could not create new libp2p host"))
|
|
}
|
|
|
|
info := peer.AddrInfo{
|
|
ID: h.ID(),
|
|
Addrs: h.Addrs(),
|
|
}
|
|
if err := p.Connect(info); err != nil {
|
|
panic(errors.Wrap(err, "could not connect to peer"))
|
|
}
|
|
regularsync.NewService(context.Background(), ®ularsync.Config{
|
|
P2P: p,
|
|
DB: nil,
|
|
AttPool: nil,
|
|
ExitPool: nil,
|
|
SlashingPool: nil,
|
|
Chain: &mock.ChainService{
|
|
Root: bytesutil.PadTo([]byte("root"), 32),
|
|
FinalizedCheckPoint: ðpb.Checkpoint{Epoch: 4, Root: make([]byte, 32)},
|
|
Fork: &pb.Fork{CurrentVersion: []byte("foo")},
|
|
},
|
|
StateNotifier: (&mock.ChainService{}).StateNotifier(),
|
|
OperationNotifier: (&mock.ChainService{}).OperationNotifier(),
|
|
InitialSync: &mockSync.Sync{IsSyncing: false},
|
|
BlockNotifier: nil,
|
|
})
|
|
}
|
|
|
|
// FuzzP2PRPCStatus wraps BeaconFuzzP2PRPCStatus in a go-fuzz compatible interface
|
|
func FuzzP2PRPCStatus(b []byte) int {
|
|
BeaconFuzzP2PRPCStatus(b)
|
|
return 0
|
|
}
|
|
|
|
// BeaconFuzzP2PRPCStatus implements libfuzzer and beacon fuzz interface.
|
|
func BeaconFuzzP2PRPCStatus(b []byte) {
|
|
s, err := h.NewStream(context.Background(), p.PeerID(), "/eth2/beacon_chain/req/status/1/ssz_snappy")
|
|
if err != nil {
|
|
// libp2p ¯\_(ツ)_/¯
|
|
if strings.Contains(err.Error(), "stream reset") || strings.Contains(err.Error(), "connection reset by peer") || strings.Contains(err.Error(), "max dial attempts exceeded") {
|
|
return
|
|
}
|
|
panic(errors.Wrap(err, "failed to open stream"))
|
|
}
|
|
if s == nil {
|
|
panic("nil stream")
|
|
}
|
|
defer func() {
|
|
err := s.Close()
|
|
_ = err
|
|
}()
|
|
_, err = s.Write(b)
|
|
_ = err
|
|
}
|