2021-10-29 11:24:31 -04:00
|
|
|
package node
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2021-11-23 11:03:12 -04:00
|
|
|
"sync"
|
2021-10-29 11:24:31 -04:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/libp2p/go-libp2p"
|
2021-11-24 16:11:24 -04:00
|
|
|
"github.com/libp2p/go-libp2p-core/peer"
|
2021-10-29 11:24:31 -04:00
|
|
|
"github.com/libp2p/go-libp2p-core/peerstore"
|
2022-05-06 15:29:31 -04:00
|
|
|
"github.com/status-im/go-waku/waku/v2/utils"
|
2021-10-29 11:24:31 -04:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestKeepAlive(t *testing.T) {
|
|
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
|
|
defer cancel()
|
|
|
|
|
2022-03-22 09:12:58 -04:00
|
|
|
host1, err := libp2p.New(libp2p.DefaultTransports, libp2p.ListenAddrStrings("/ip4/0.0.0.0/tcp/0"))
|
2021-10-29 11:24:31 -04:00
|
|
|
require.NoError(t, err)
|
2022-03-22 09:12:58 -04:00
|
|
|
host2, err := libp2p.New(libp2p.DefaultTransports, libp2p.ListenAddrStrings("/ip4/0.0.0.0/tcp/0"))
|
2021-10-29 11:24:31 -04:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
host1.Peerstore().AddAddrs(host2.ID(), host2.Addrs(), peerstore.PermanentAddrTTL)
|
|
|
|
|
|
|
|
err = host1.Connect(ctx, host1.Peerstore().PeerInfo(host2.ID()))
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
require.Len(t, host1.Network().Peers(), 1)
|
|
|
|
|
|
|
|
ctx2, cancel2 := context.WithTimeout(ctx, 3*time.Second)
|
|
|
|
defer cancel2()
|
2021-11-23 11:03:12 -04:00
|
|
|
wg := &sync.WaitGroup{}
|
|
|
|
|
2021-11-24 16:11:24 -04:00
|
|
|
w := &WakuNode{
|
|
|
|
host: host1,
|
|
|
|
ctx: ctx2,
|
|
|
|
wg: wg,
|
2022-05-06 15:29:31 -04:00
|
|
|
log: utils.Logger(),
|
2021-11-24 16:11:24 -04:00
|
|
|
keepAliveMutex: sync.Mutex{},
|
|
|
|
keepAliveFails: make(map[peer.ID]int),
|
|
|
|
}
|
|
|
|
|
|
|
|
w.wg.Add(1)
|
|
|
|
w.pingPeer(host2.ID())
|
2021-10-29 11:24:31 -04:00
|
|
|
|
|
|
|
require.NoError(t, ctx.Err())
|
|
|
|
}
|