{.used.} import std/[options, tables, sets], testutils/unittests, chronos, chronicles, stew/shims/net as stewNet, libp2p/switch, libp2p/protobuf/minprotobuf, libp2p/protocols/ping, libp2p/stream/[bufferstream, connection], libp2p/crypto/crypto, libp2p/multistream, ../../waku/v2/node/wakunode2, ../test_helpers, ./utils procSuite "Waku Keepalive": asyncTest "handle ping keepalives": let nodeKey1 = crypto.PrivateKey.random(Secp256k1, rng[])[] node1 = WakuNode.init(nodeKey1, ValidIpAddress.init("0.0.0.0"), Port(60000)) nodeKey2 = crypto.PrivateKey.random(Secp256k1, rng[])[] node2 = WakuNode.init(nodeKey2, ValidIpAddress.init("0.0.0.0"), Port(60002)) var completionFut = newFuture[bool]() proc pingHandler(peer: PeerInfo) {.async, gcsafe, raises: [Defect].} = debug "Ping received" check: peer.peerId == node1.switch.peerInfo.peerId completionFut.complete(true) await node1.start() node1.mountRelay() node1.mountLibp2pPing() await node2.start() node2.mountRelay() node2.switch.mount(Ping.new(handler = pingHandler)) await node1.connectToNodes(@[node2.peerInfo]) node1.startKeepalive() check: (await completionFut.withTimeout(5.seconds)) == true await allFutures([node1.stop(), node2.stop()])