2019-11-30 05:36:02 +00:00
|
|
|
package testing
|
|
|
|
|
|
|
|
import (
|
2020-07-19 03:45:08 +00:00
|
|
|
"context"
|
2019-12-11 10:31:36 +00:00
|
|
|
"sync"
|
|
|
|
|
2020-06-18 03:53:46 +00:00
|
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
|
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
2020-04-14 20:27:03 +00:00
|
|
|
"github.com/ethereum/go-ethereum/p2p/enr"
|
2019-11-30 05:36:02 +00:00
|
|
|
"github.com/libp2p/go-libp2p-core/network"
|
2020-07-13 02:28:40 +00:00
|
|
|
"github.com/libp2p/go-libp2p-core/peer"
|
2019-11-30 05:36:02 +00:00
|
|
|
ma "github.com/multiformats/go-multiaddr"
|
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/p2p/peers"
|
2020-10-07 13:08:51 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/p2p/peers/scorers"
|
2019-12-11 10:31:36 +00:00
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
2020-04-14 16:41:09 +00:00
|
|
|
log "github.com/sirupsen/logrus"
|
2019-11-30 05:36:02 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// MockPeersProvider implements PeersProvider for testing.
|
|
|
|
type MockPeersProvider struct {
|
2019-12-11 10:31:36 +00:00
|
|
|
lock sync.Mutex
|
|
|
|
peers *peers.Status
|
2019-11-30 05:36:02 +00:00
|
|
|
}
|
|
|
|
|
2021-01-20 15:52:33 +00:00
|
|
|
// ClearPeers removes all known peers.
|
|
|
|
func (m *MockPeersProvider) ClearPeers() {
|
|
|
|
m.lock.Lock()
|
|
|
|
defer m.lock.Unlock()
|
|
|
|
m.peers = peers.NewStatus(context.Background(), &peers.StatusConfig{
|
|
|
|
PeerLimit: 30,
|
|
|
|
ScorerParams: &scorers.Config{
|
|
|
|
BadResponsesScorerConfig: &scorers.BadResponsesScorerConfig{
|
|
|
|
Threshold: 5,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-12-11 10:31:36 +00:00
|
|
|
// Peers provides access the peer status.
|
|
|
|
func (m *MockPeersProvider) Peers() *peers.Status {
|
|
|
|
m.lock.Lock()
|
|
|
|
defer m.lock.Unlock()
|
|
|
|
if m.peers == nil {
|
2020-07-19 03:45:08 +00:00
|
|
|
m.peers = peers.NewStatus(context.Background(), &peers.StatusConfig{
|
2020-07-20 15:12:59 +00:00
|
|
|
PeerLimit: 30,
|
2020-10-07 13:08:51 +00:00
|
|
|
ScorerParams: &scorers.Config{
|
|
|
|
BadResponsesScorerConfig: &scorers.BadResponsesScorerConfig{
|
2020-07-29 09:26:46 +00:00
|
|
|
Threshold: 5,
|
|
|
|
},
|
2020-07-20 15:12:59 +00:00
|
|
|
},
|
2020-07-19 03:45:08 +00:00
|
|
|
})
|
2019-12-11 10:31:36 +00:00
|
|
|
// Pretend we are connected to two peers
|
2020-07-13 02:28:40 +00:00
|
|
|
id0, err := peer.Decode("16Uiu2HAkyWZ4Ni1TpvDS8dPxsozmHY85KaiFjodQuV6Tz5tkHVeR")
|
2020-04-14 16:41:09 +00:00
|
|
|
if err != nil {
|
|
|
|
log.WithError(err).Debug("Cannot decode")
|
|
|
|
}
|
|
|
|
ma0, err := ma.NewMultiaddr("/ip4/213.202.254.180/tcp/13000")
|
|
|
|
if err != nil {
|
2020-04-14 20:27:03 +00:00
|
|
|
log.WithError(err).Debug("Cannot decode")
|
2020-04-14 16:41:09 +00:00
|
|
|
}
|
2020-06-18 03:53:46 +00:00
|
|
|
m.peers.Add(createENR(), id0, ma0, network.DirInbound)
|
2019-12-11 10:31:36 +00:00
|
|
|
m.peers.SetConnectionState(id0, peers.PeerConnected)
|
2021-02-09 10:05:22 +00:00
|
|
|
m.peers.SetChainState(id0, &pb.Status{FinalizedEpoch: 10})
|
2020-07-13 02:28:40 +00:00
|
|
|
id1, err := peer.Decode("16Uiu2HAm4HgJ9N1o222xK61o7LSgToYWoAy1wNTJRkh9gLZapVAy")
|
2020-04-14 16:41:09 +00:00
|
|
|
if err != nil {
|
|
|
|
log.WithError(err).Debug("Cannot decode")
|
|
|
|
}
|
|
|
|
ma1, err := ma.NewMultiaddr("/ip4/52.23.23.253/tcp/30000/ipfs/QmfAgkmjiZNZhr2wFN9TwaRgHouMTBT6HELyzE5A3BT2wK/p2p-circuit")
|
|
|
|
if err != nil {
|
2020-04-14 20:27:03 +00:00
|
|
|
log.WithError(err).Debug("Cannot decode")
|
2020-04-14 16:41:09 +00:00
|
|
|
}
|
2020-06-18 03:53:46 +00:00
|
|
|
m.peers.Add(createENR(), id1, ma1, network.DirOutbound)
|
2019-12-11 10:31:36 +00:00
|
|
|
m.peers.SetConnectionState(id1, peers.PeerConnected)
|
2021-02-09 10:05:22 +00:00
|
|
|
m.peers.SetChainState(id1, &pb.Status{FinalizedEpoch: 11})
|
2019-11-30 05:36:02 +00:00
|
|
|
}
|
2019-12-11 10:31:36 +00:00
|
|
|
return m.peers
|
2019-11-30 05:36:02 +00:00
|
|
|
}
|
2020-06-18 03:53:46 +00:00
|
|
|
|
|
|
|
func createENR() *enr.Record {
|
|
|
|
key, err := crypto.GenerateKey()
|
2020-10-01 18:53:36 +00:00
|
|
|
if err != nil {
|
|
|
|
log.Error(err)
|
|
|
|
}
|
2020-06-18 03:53:46 +00:00
|
|
|
db, err := enode.OpenDB("")
|
|
|
|
if err != nil {
|
|
|
|
log.Error("could not open node's peer database")
|
|
|
|
}
|
|
|
|
lNode := enode.NewLocalNode(db, key)
|
|
|
|
return lNode.Node().Record()
|
|
|
|
}
|