2022-10-23 09:13:43 -04:00
|
|
|
package peer_exchange
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
|
|
|
"github.com/libp2p/go-libp2p/core/peerstore"
|
2023-08-15 21:40:00 -04:00
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
2022-10-23 09:13:43 -04:00
|
|
|
"github.com/stretchr/testify/require"
|
2022-11-09 15:53:01 -04:00
|
|
|
"github.com/waku-org/go-waku/tests"
|
|
|
|
"github.com/waku-org/go-waku/waku/v2/discv5"
|
2023-04-20 14:51:13 -04:00
|
|
|
wenr "github.com/waku-org/go-waku/waku/v2/protocol/enr"
|
2022-11-09 15:53:01 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/utils"
|
2022-10-23 09:13:43 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestRetrieveProvidePeerExchangePeers(t *testing.T) {
|
|
|
|
// H1
|
2023-11-07 22:43:19 +05:30
|
|
|
host1, _, prvKey1 := tests.CreateHost(t)
|
2022-10-23 09:13:43 -04:00
|
|
|
udpPort1, err := tests.FindFreePort(t, "127.0.0.1", 3)
|
|
|
|
require.NoError(t, err)
|
2023-11-07 22:43:19 +05:30
|
|
|
ip1, _ := tests.ExtractIP(host1.Addrs()[0])
|
|
|
|
l1, err := tests.NewLocalnode(prvKey1, ip1, udpPort1, wenr.NewWakuEnrBitfield(false, false, false, true), nil, utils.Logger())
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
2023-11-07 22:43:19 +05:30
|
|
|
discv5PeerConn1 := discv5.NewTestPeerDiscoverer()
|
2023-08-15 21:40:00 -04:00
|
|
|
d1, err := discv5.NewDiscoveryV5(prvKey1, l1, discv5PeerConn1, prometheus.DefaultRegisterer, utils.Logger(), discv5.WithUDPPort(uint(udpPort1)))
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
2023-04-16 20:04:12 -04:00
|
|
|
d1.SetHost(host1)
|
2022-10-23 09:13:43 -04:00
|
|
|
|
|
|
|
// H2
|
2023-11-07 22:43:19 +05:30
|
|
|
host2, _, prvKey2 := tests.CreateHost(t)
|
|
|
|
ip2, _ := tests.ExtractIP(host2.Addrs()[0])
|
2022-10-23 09:13:43 -04:00
|
|
|
udpPort2, err := tests.FindFreePort(t, "127.0.0.1", 3)
|
|
|
|
require.NoError(t, err)
|
2023-11-07 22:43:19 +05:30
|
|
|
l2, err := tests.NewLocalnode(prvKey2, ip2, udpPort2, wenr.NewWakuEnrBitfield(false, false, false, true), nil, utils.Logger())
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
2023-11-07 22:43:19 +05:30
|
|
|
discv5PeerConn2 := discv5.NewTestPeerDiscoverer()
|
2023-08-15 21:40:00 -04:00
|
|
|
d2, err := discv5.NewDiscoveryV5(prvKey2, l2, discv5PeerConn2, prometheus.DefaultRegisterer, utils.Logger(), discv5.WithUDPPort(uint(udpPort2)), discv5.WithBootnodes([]*enode.Node{d1.Node()}))
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
2023-04-16 20:04:12 -04:00
|
|
|
d2.SetHost(host2)
|
2022-10-23 09:13:43 -04:00
|
|
|
|
|
|
|
// H3
|
2023-11-07 22:43:19 +05:30
|
|
|
host3, _, _ := tests.CreateHost(t)
|
2022-10-23 09:13:43 -04:00
|
|
|
|
|
|
|
defer d1.Stop()
|
|
|
|
defer d2.Stop()
|
|
|
|
defer host1.Close()
|
|
|
|
defer host2.Close()
|
|
|
|
defer host3.Close()
|
|
|
|
|
2022-12-10 11:38:18 -04:00
|
|
|
err = d1.Start(context.Background())
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2022-12-10 11:38:18 -04:00
|
|
|
err = d2.Start(context.Background())
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2022-11-29 13:39:34 -04:00
|
|
|
time.Sleep(3 * time.Second) // Wait some time for peers to be discovered
|
|
|
|
|
2022-10-23 09:13:43 -04:00
|
|
|
// mount peer exchange
|
2023-11-07 22:43:19 +05:30
|
|
|
pxPeerConn1 := discv5.NewTestPeerDiscoverer()
|
2023-08-15 21:40:00 -04:00
|
|
|
px1, err := NewWakuPeerExchange(d1, pxPeerConn1, nil, prometheus.DefaultRegisterer, utils.Logger())
|
2023-01-10 20:52:10 -04:00
|
|
|
require.NoError(t, err)
|
2023-04-16 20:04:12 -04:00
|
|
|
px1.SetHost(host1)
|
2023-01-10 20:52:10 -04:00
|
|
|
|
2023-11-07 22:43:19 +05:30
|
|
|
pxPeerConn3 := discv5.NewTestPeerDiscoverer()
|
2023-08-15 21:40:00 -04:00
|
|
|
px3, err := NewWakuPeerExchange(nil, pxPeerConn3, nil, prometheus.DefaultRegisterer, utils.Logger())
|
2023-01-10 20:52:10 -04:00
|
|
|
require.NoError(t, err)
|
2023-04-16 20:04:12 -04:00
|
|
|
px3.SetHost(host3)
|
2022-10-23 09:13:43 -04:00
|
|
|
|
2022-12-10 11:38:18 -04:00
|
|
|
err = px1.Start(context.Background())
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2022-12-10 11:38:18 -04:00
|
|
|
err = px3.Start(context.Background())
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
host3.Peerstore().AddAddrs(host1.ID(), host1.Addrs(), peerstore.PermanentAddrTTL)
|
2023-02-16 12:17:52 -04:00
|
|
|
err = host3.Peerstore().AddProtocols(host1.ID(), PeerExchangeID_v20alpha1)
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
2023-10-16 22:12:01 +05:30
|
|
|
err = px3.Request(context.Background(), 1, WithPeer(host1.ID()))
|
2022-10-23 09:13:43 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
time.Sleep(3 * time.Second) // Give the algorithm some time to work its magic
|
|
|
|
|
2023-01-13 19:58:22 -04:00
|
|
|
require.True(t, pxPeerConn3.HasPeer(host2.ID()))
|
2022-10-23 09:13:43 -04:00
|
|
|
|
|
|
|
px1.Stop()
|
|
|
|
px3.Stop()
|
|
|
|
}
|