go-waku/waku/v2/node/keepalive_test.go

90 lines
2.2 KiB
Go
Raw Permalink Normal View History

2021-10-29 15:24:31 +00:00
package node
import (
"context"
"net"
"sync"
2021-10-29 15:24:31 +00:00
"testing"
"time"
"github.com/ethereum/go-ethereum/crypto"
2021-10-29 15:24:31 +00:00
"github.com/libp2p/go-libp2p"
2022-10-19 19:39:32 +00:00
"github.com/libp2p/go-libp2p/core/peer"
"github.com/libp2p/go-libp2p/core/peerstore"
"github.com/multiformats/go-multiaddr"
2021-10-29 15:24:31 +00:00
"github.com/stretchr/testify/require"
"github.com/waku-org/go-waku/tests"
wps "github.com/waku-org/go-waku/waku/v2/peerstore"
"github.com/waku-org/go-waku/waku/v2/utils"
2021-10-29 15:24:31 +00:00
)
func TestKeepAlive(t *testing.T) {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
2022-03-22 13:12:58 +00:00
host1, err := libp2p.New(libp2p.DefaultTransports, libp2p.ListenAddrStrings("/ip4/0.0.0.0/tcp/0"))
2021-10-29 15:24:31 +00:00
require.NoError(t, err)
2022-03-22 13:12:58 +00:00
host2, err := libp2p.New(libp2p.DefaultTransports, libp2p.ListenAddrStrings("/ip4/0.0.0.0/tcp/0"))
2021-10-29 15:24:31 +00:00
require.NoError(t, err)
peerID2 := host2.ID()
2021-10-29 15:24:31 +00:00
host1.Peerstore().AddAddrs(peerID2, host2.Addrs(), peerstore.PermanentAddrTTL)
2021-10-29 15:24:31 +00:00
err = host1.Connect(ctx, host1.Peerstore().PeerInfo(peerID2))
2021-10-29 15:24:31 +00:00
require.NoError(t, err)
require.Len(t, host1.Network().Peers(), 1)
ctx2, cancel2 := context.WithTimeout(ctx, 3*time.Second)
defer cancel2()
wg := &sync.WaitGroup{}
w := &WakuNode{
host: host1,
wg: wg,
2022-05-06 19:29:31 +00:00
log: utils.Logger(),
keepAliveMutex: sync.Mutex{},
keepAliveFails: make(map[peer.ID]int),
}
w.wg.Add(1)
w.pingPeer(ctx2, w.wg, peerID2, false)
2021-10-29 15:24:31 +00:00
require.NoError(t, ctx.Err())
}
func TestPeriodicKeepAlive(t *testing.T) {
hostAddr, _ := net.ResolveTCPAddr("tcp", "0.0.0.0:0")
host1, err := libp2p.New(libp2p.DefaultTransports, libp2p.ListenAddrStrings("/ip4/0.0.0.0/tcp/0"))
require.NoError(t, err)
key, err := tests.RandomHex(32)
require.NoError(t, err)
prvKey, err := crypto.HexToECDSA(key)
require.NoError(t, err)
ctx := context.Background()
wakuNode, err := New(
WithPrivateKey(prvKey),
WithHostAddress(hostAddr),
WithWakuRelay(),
WithKeepAlive(time.Second),
)
require.NoError(t, err)
err = wakuNode.Start(ctx)
require.NoError(t, err)
node2MAddr, err := multiaddr.NewMultiaddr(host1.Addrs()[0].String() + "/p2p/" + host1.ID().Pretty())
require.NoError(t, err)
_, err = wakuNode.AddPeer(node2MAddr, wps.Static, []string{"waku/rs/1/1"})
require.NoError(t, err)
time.Sleep(time.Second * 2)
defer wakuNode.Stop()
}