mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-16 06:58:20 +00:00
89 lines
2.4 KiB
Go
89 lines
2.4 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/network"
|
||
|
"github.com/libp2p/go-libp2p-core/peer"
|
||
|
"github.com/pkg/errors"
|
||
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
||
|
mock "github.com/prysmaticlabs/prysm/beacon-chain/blockchain/testing"
|
||
|
"github.com/prysmaticlabs/prysm/beacon-chain/cache"
|
||
|
"github.com/prysmaticlabs/prysm/beacon-chain/p2p"
|
||
|
"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"
|
||
|
"github.com/sirupsen/logrus"
|
||
|
)
|
||
|
|
||
|
var p *p2p.Service
|
||
|
var s network.Stream
|
||
|
var h host.Host
|
||
|
|
||
|
func init() {
|
||
|
logrus.SetLevel(logrus.PanicLevel)
|
||
|
|
||
|
var err error
|
||
|
p, err = p2p.NewService(&p2p.Config{
|
||
|
NoDiscovery: true,
|
||
|
Encoding: "ssz",
|
||
|
})
|
||
|
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"))
|
||
|
}
|
||
|
sync.NewRegularSync(&sync.Config{
|
||
|
P2P: p,
|
||
|
DB: nil,
|
||
|
AttPool: nil,
|
||
|
ExitPool: nil,
|
||
|
SlashingPool: nil,
|
||
|
Chain: &mock.ChainService{
|
||
|
Root: []byte("root"),
|
||
|
FinalizedCheckPoint: ðpb.Checkpoint{Epoch: 4},
|
||
|
Fork: &pb.Fork{CurrentVersion: []byte("foo")},
|
||
|
},
|
||
|
StateNotifier: (&mock.ChainService{}).StateNotifier(),
|
||
|
AttestationNotifier: (&mock.ChainService{}).OperationNotifier(),
|
||
|
InitialSync: &mockSync.Sync{IsSyncing: false},
|
||
|
StateSummaryCache: cache.NewStateSummaryCache(),
|
||
|
BlockNotifier: nil,
|
||
|
})
|
||
|
}
|
||
|
|
||
|
// 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")
|
||
|
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
|
||
|
}
|