2022-08-23 15:49:07 +00:00
|
|
|
import std/options
|
|
|
|
import chronos
|
|
|
|
import
|
|
|
|
../libp2p/[
|
2022-12-22 19:29:31 +00:00
|
|
|
transports/tcptransport,
|
|
|
|
upgrademngrs/upgrade,
|
2022-08-23 15:49:07 +00:00
|
|
|
builders,
|
2022-09-15 07:43:40 +00:00
|
|
|
protocols/connectivity/autonat
|
2022-08-23 15:49:07 +00:00
|
|
|
],
|
|
|
|
./helpers
|
|
|
|
|
|
|
|
proc createAutonatSwitch(): Switch =
|
|
|
|
result = SwitchBuilder.new()
|
|
|
|
.withRng(newRng())
|
|
|
|
.withAddresses(@[ MultiAddress.init("/ip4/0.0.0.0/tcp/0").tryGet() ])
|
|
|
|
.withTcpTransport()
|
|
|
|
.withMplex()
|
|
|
|
.withAutonat()
|
|
|
|
.withNoise()
|
|
|
|
.build()
|
|
|
|
|
|
|
|
proc makeAutonatServicePrivate(): Switch =
|
|
|
|
var autonatProtocol = new LPProtocol
|
|
|
|
autonatProtocol.handler = proc (conn: Connection, proto: string) {.async, gcsafe.} =
|
|
|
|
discard await conn.readLp(1024)
|
|
|
|
await conn.writeLp(AutonatDialResponse(
|
|
|
|
status: DialError,
|
|
|
|
text: some("dial failed"),
|
|
|
|
ma: none(MultiAddress)).encode().buffer)
|
|
|
|
await conn.close()
|
|
|
|
autonatProtocol.codec = AutonatCodec
|
|
|
|
result = newStandardSwitch()
|
|
|
|
result.mount(autonatProtocol)
|
|
|
|
|
|
|
|
suite "Autonat":
|
|
|
|
teardown:
|
|
|
|
checkTrackers()
|
|
|
|
|
2022-12-22 16:33:59 +00:00
|
|
|
asyncTest "dialMe returns public address":
|
2022-08-23 15:49:07 +00:00
|
|
|
let
|
|
|
|
src = newStandardSwitch()
|
|
|
|
dst = createAutonatSwitch()
|
|
|
|
await src.start()
|
|
|
|
await dst.start()
|
|
|
|
|
|
|
|
await src.connect(dst.peerInfo.peerId, dst.peerInfo.addrs)
|
|
|
|
let ma = await Autonat.new(src).dialMe(dst.peerInfo.peerId, dst.peerInfo.addrs)
|
2022-12-22 16:33:59 +00:00
|
|
|
check ma in src.peerInfo.addrs
|
2022-08-23 15:49:07 +00:00
|
|
|
await allFutures(src.stop(), dst.stop())
|
|
|
|
|
2022-12-22 16:33:59 +00:00
|
|
|
asyncTest "dialMe handles dial error msg":
|
2022-08-23 15:49:07 +00:00
|
|
|
let
|
|
|
|
src = newStandardSwitch()
|
|
|
|
dst = makeAutonatServicePrivate()
|
|
|
|
|
|
|
|
await src.start()
|
|
|
|
await dst.start()
|
|
|
|
|
|
|
|
await src.connect(dst.peerInfo.peerId, dst.peerInfo.addrs)
|
2022-12-22 16:33:59 +00:00
|
|
|
expect AutonatUnreachableError:
|
2022-08-23 15:49:07 +00:00
|
|
|
discard await Autonat.new(src).dialMe(dst.peerInfo.peerId, dst.peerInfo.addrs)
|
|
|
|
await allFutures(src.stop(), dst.stop())
|
2022-12-22 19:29:31 +00:00
|
|
|
|
|
|
|
asyncTest "Timeout is triggered in autonat handle":
|
|
|
|
let
|
|
|
|
src = newStandardSwitch()
|
|
|
|
dst = newStandardSwitch()
|
|
|
|
autonat = Autonat.new(dst, dialTimeout = 1.seconds)
|
|
|
|
doesNothingListener = TcpTransport.new(upgrade = Upgrade())
|
|
|
|
|
|
|
|
dst.mount(autonat)
|
|
|
|
await src.start()
|
|
|
|
await dst.start()
|
|
|
|
await doesNothingListener.start(@[MultiAddress.init("/ip4/0.0.0.0/tcp/0").tryGet()])
|
|
|
|
|
|
|
|
await src.connect(dst.peerInfo.peerId, dst.peerInfo.addrs)
|
|
|
|
let conn = await src.dial(dst.peerInfo.peerId, @[AutonatCodec])
|
|
|
|
let buffer = AutonatDial(peerInfo: some(AutonatPeerInfo(
|
|
|
|
id: some(src.peerInfo.peerId),
|
|
|
|
# we ask to be dialed in the does nothing listener instead
|
|
|
|
addrs: doesNothingListener.addrs
|
|
|
|
))).encode().buffer
|
|
|
|
await conn.writeLp(buffer)
|
|
|
|
let response = AutonatMsg.decode(await conn.readLp(1024)).get().response.get()
|
|
|
|
check:
|
|
|
|
response.status == DialError
|
|
|
|
response.text.get() == "Timeout exceeded!"
|
|
|
|
response.ma.isNone()
|
|
|
|
await allFutures(doesNothingListener.stop(), src.stop(), dst.stop())
|