mirror of
https://github.com/status-im/go-waku.git
synced 2025-01-19 10:13:37 +00:00
3226def4cf
* refactor discovery and common service to separate package to remove package inter-dependencies * relay on-demand discovery ,use proto to enr field mapping * chore: no need to dial discovered peers as peermanager already does that * on demand discovery for service peers during peer selection * identify supported protocols for discovered peers and add to service slots * fix: tests to use proper static sharding topics * fix: random selection with default pubsubTopic --------- Co-authored-by: richΛrd <info@richardramos.me>
63 lines
1.3 KiB
Go
63 lines
1.3 KiB
Go
package discv5
|
|
|
|
import (
|
|
"context"
|
|
"sync"
|
|
|
|
"github.com/libp2p/go-libp2p/core/peer"
|
|
"github.com/waku-org/go-waku/waku/v2/service"
|
|
)
|
|
|
|
// TestPeerDiscoverer is mock peer discoverer for testing
|
|
type TestPeerDiscoverer struct {
|
|
sync.RWMutex
|
|
peerMap map[peer.ID]struct{}
|
|
}
|
|
|
|
// NewTestPeerDiscoverer is a constructor for TestPeerDiscoverer
|
|
func NewTestPeerDiscoverer() *TestPeerDiscoverer {
|
|
result := &TestPeerDiscoverer{
|
|
peerMap: make(map[peer.ID]struct{}),
|
|
}
|
|
|
|
return result
|
|
}
|
|
|
|
// Subscribe is for subscribing to peer discoverer
|
|
func (t *TestPeerDiscoverer) Subscribe(ctx context.Context, ch <-chan service.PeerData) {
|
|
go func() {
|
|
for {
|
|
select {
|
|
case <-ctx.Done():
|
|
return
|
|
case p := <-ch:
|
|
t.Lock()
|
|
t.peerMap[p.AddrInfo.ID] = struct{}{}
|
|
t.Unlock()
|
|
}
|
|
}
|
|
}()
|
|
}
|
|
|
|
// HasPeer is for checking if a peer is present in peer discoverer
|
|
func (t *TestPeerDiscoverer) HasPeer(p peer.ID) bool {
|
|
t.RLock()
|
|
defer t.RUnlock()
|
|
_, ok := t.peerMap[p]
|
|
return ok
|
|
}
|
|
|
|
// PeerCount is for getting the number of peers in peer discoverer
|
|
func (t *TestPeerDiscoverer) PeerCount() int {
|
|
t.RLock()
|
|
defer t.RUnlock()
|
|
return len(t.peerMap)
|
|
}
|
|
|
|
// Clear is for clearing the peer discoverer
|
|
func (t *TestPeerDiscoverer) Clear() {
|
|
t.Lock()
|
|
defer t.Unlock()
|
|
t.peerMap = make(map[peer.ID]struct{})
|
|
}
|