mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-28 15:46:33 +00:00
114 lines
3.4 KiB
Nim
114 lines
3.4 KiB
Nim
|
{.used.}
|
||
|
|
||
|
import
|
||
|
std/[tables, sequtils],
|
||
|
chronicles,
|
||
|
chronos,
|
||
|
testutils/unittests,
|
||
|
stew/byteutils,
|
||
|
stew/shims/net,
|
||
|
libp2p/crypto/crypto,
|
||
|
eth/keys,
|
||
|
eth/p2p/discoveryv5/enr,
|
||
|
../../waku/v2/node/discv5/waku_discv5,
|
||
|
../../waku/v2/node/wakunode2,
|
||
|
../test_helpers
|
||
|
|
||
|
procSuite "Waku Discovery v5":
|
||
|
asyncTest "Waku Discovery v5 end-to-end":
|
||
|
## Tests integrated discovery v5
|
||
|
let
|
||
|
bindIp = ValidIpAddress.init("0.0.0.0")
|
||
|
extIp = ValidIpAddress.init("127.0.0.1")
|
||
|
|
||
|
nodeKey1 = crypto.PrivateKey.random(Secp256k1, rng[])[]
|
||
|
nodeTcpPort1 = Port(60000)
|
||
|
nodeUdpPort1 = Port(9000)
|
||
|
node1 = WakuNode.new(nodeKey1, bindIp, nodeTcpPort1)
|
||
|
|
||
|
nodeKey2 = crypto.PrivateKey.random(Secp256k1, rng[])[]
|
||
|
nodeTcpPort2 = Port(60002)
|
||
|
nodeUdpPort2 = Port(9002)
|
||
|
node2 = WakuNode.new(nodeKey2, bindIp, nodeTcpPort2)
|
||
|
|
||
|
nodeKey3 = crypto.PrivateKey.random(Secp256k1, rng[])[]
|
||
|
nodeTcpPort3 = Port(60004)
|
||
|
nodeUdpPort3 = Port(9004)
|
||
|
node3 = WakuNode.new(nodeKey3, bindIp, nodeTcpPort3)
|
||
|
|
||
|
# E2E relay test paramaters
|
||
|
pubSubTopic = "/waku/2/default-waku/proto"
|
||
|
contentTopic = ContentTopic("/waku/2/default-content/proto")
|
||
|
payload = "Can you see me?".toBytes()
|
||
|
message = WakuMessage(payload: payload, contentTopic: contentTopic)
|
||
|
|
||
|
# Mount discv5
|
||
|
node1.wakuDiscv5 = WakuDiscoveryV5.new(
|
||
|
some(extIp), some(nodeTcpPort1), some(nodeUdpPort1),
|
||
|
bindIp,
|
||
|
nodeUdpPort1,
|
||
|
@[],
|
||
|
false,
|
||
|
keys.PrivateKey(nodeKey1.skkey),
|
||
|
[], # Empty enr fields, for now
|
||
|
node1.rng
|
||
|
)
|
||
|
|
||
|
node2.wakuDiscv5 = WakuDiscoveryV5.new(
|
||
|
some(extIp), some(nodeTcpPort2), some(nodeUdpPort2),
|
||
|
bindIp,
|
||
|
nodeUdpPort2,
|
||
|
@[node1.wakuDiscv5.protocol.localNode.record.toURI()], # Bootstrap with node1
|
||
|
false,
|
||
|
keys.PrivateKey(nodeKey2.skkey),
|
||
|
[], # Empty enr fields, for now
|
||
|
node2.rng
|
||
|
)
|
||
|
|
||
|
node3.wakuDiscv5 = WakuDiscoveryV5.new(
|
||
|
some(extIp), some(nodeTcpPort3), some(nodeUdpPort3),
|
||
|
bindIp,
|
||
|
nodeUdpPort3,
|
||
|
@[node2.wakuDiscv5.protocol.localNode.record.toURI()], # Bootstrap with node2
|
||
|
false,
|
||
|
keys.PrivateKey(nodeKey3.skkey),
|
||
|
[], # Empty enr fields, for now
|
||
|
node3.rng
|
||
|
)
|
||
|
|
||
|
node1.mountRelay()
|
||
|
node2.mountRelay()
|
||
|
node3.mountRelay()
|
||
|
|
||
|
await allFutures([node1.start(), node2.start(), node3.start()])
|
||
|
|
||
|
await allFutures([node1.startDiscv5(), node2.startDiscv5(), node3.startDiscv5()])
|
||
|
|
||
|
await sleepAsync(3000.millis) # Give the algorithm some time to work its magic
|
||
|
check:
|
||
|
node1.wakuDiscv5.protocol.nodesDiscovered > 0
|
||
|
node2.wakuDiscv5.protocol.nodesDiscovered > 0
|
||
|
node3.wakuDiscv5.protocol.nodesDiscovered > 0
|
||
|
|
||
|
# Let's see if we can deliver a message end-to-end
|
||
|
var completionFut = newFuture[bool]()
|
||
|
proc relayHandler(topic: string, data: seq[byte]) {.async, gcsafe.} =
|
||
|
let msg = WakuMessage.init(data)
|
||
|
if msg.isOk():
|
||
|
let val = msg.value()
|
||
|
check:
|
||
|
topic == pubSubTopic
|
||
|
val.contentTopic == contentTopic
|
||
|
val.payload == payload
|
||
|
completionFut.complete(true)
|
||
|
|
||
|
node3.subscribe(pubSubTopic, relayHandler)
|
||
|
await sleepAsync(2000.millis)
|
||
|
|
||
|
await node1.publish(pubSubTopic, message)
|
||
|
|
||
|
check:
|
||
|
(await completionFut.withTimeout(6.seconds)) == true
|
||
|
|
||
|
await allFutures([node1.stop(), node2.stop(), node3.stop()])
|