feat: adding dial/listen test with transports on both ends

This commit is contained in:
Dmitriy Ryajov 2019-08-21 17:13:20 -06:00
parent c15a9bdd67
commit a91c15c47a
4 changed files with 74 additions and 35 deletions

View File

@ -23,19 +23,22 @@ method init*(t: TcpTransport) =
method close*(t: TcpTransport): Future[void] {.async.} = method close*(t: TcpTransport): Future[void] {.async.} =
## start the transport ## start the transport
await procCall Transport(t).close() # call base close await procCall Transport(t).close() # call base
t.server.stop() t.server.stop()
await t.server.closeWait() await t.server.closeWait()
method listen*(t: TcpTransport): Future[void] {.async.} = method listen*(t: TcpTransport, ma: MultiAddress, handler: ConnHandler): Future[void] {.async.} =
await procCall Transport(t).listen(ma, handler) # call base
## listen on the transport
let listenFuture: Future[void] = newFuture[void]() let listenFuture: Future[void] = newFuture[void]()
result = listenFuture result = listenFuture
## listen on the transport
let server = createStreamServer(t.ma, connCb, {}, t) let server = createStreamServer(t.ma, connCb, {}, t)
t.server = server t.server = server
server.start() server.start()
listenFuture.complete()
method dial*(t: TcpTransport, address: MultiAddress): Future[Connection] {.async.} = method dial*(t: TcpTransport, address: MultiAddress): Future[Connection] {.async.} =
## dial a peer ## dial a peer

View File

@ -37,12 +37,8 @@ method init*(t: Transport) {.base.} =
## perform protocol initialization ## perform protocol initialization
discard discard
proc newTransport*(t: typedesc[Transport], proc newTransport*(t: typedesc[Transport]): t =
ma: MultiAddress,
handler: ConnHandler = nil): t =
new result new result
result.ma = ma
result.handler = handler
result.init() result.init()
method close*(t: Transport) {.base, async.} = method close*(t: Transport) {.base, async.} =
@ -52,9 +48,10 @@ method close*(t: Transport) {.base, async.} =
if c.connection.isOpen: if c.connection.isOpen:
await c.connection.close() await c.connection.close()
method listen*(t: Transport) {.base, async.} = method listen*(t: Transport, ma: MultiAddress, handler: ConnHandler) {.base, async.} =
## listen for incoming connections ## listen for incoming connections
discard t.ma = ma
t.handler = handler
method dial*(t: Transport, address: MultiAddress): Future[Connection] {.base, async.} = method dial*(t: Transport, address: MultiAddress): Future[Connection] {.base, async.} =
## dial a peer ## dial a peer

Binary file not shown.

View File

@ -11,8 +11,8 @@ suite "TCP transport suite":
result = conn.write(cstring("Hello!"), 6) result = conn.write(cstring("Hello!"), 6)
await conn.close() await conn.close()
let transport: TcpTransport = newTransport(TcpTransport, ma, connHandler) let transport: TcpTransport = newTransport(TcpTransport)
await transport.listen() await transport.listen(ma, connHandler)
let streamTransport: StreamTransport = await connect(ma) let streamTransport: StreamTransport = await connect(ma)
let msg = await streamTransport.read(6) let msg = await streamTransport.read(6)
await transport.close() await transport.close()
@ -30,8 +30,8 @@ suite "TCP transport suite":
let msg = await conn.read(6) let msg = await conn.read(6)
check cast[string](msg) == "Hello!" check cast[string](msg) == "Hello!"
let transport: TcpTransport = newTransport(TcpTransport, ma, connHandler) let transport: TcpTransport = newTransport(TcpTransport)
await transport.listen() await transport.listen(ma, connHandler)
let streamTransport: StreamTransport = await connect(ma) let streamTransport: StreamTransport = await connect(ma)
let sent = await streamTransport.write("Hello!", 6) let sent = await streamTransport.write("Hello!", 6)
result = sent == 6 result = sent == 6
@ -55,7 +55,7 @@ suite "TCP transport suite":
server.start() server.start()
let ma: MultiAddress = Multiaddress.init("/ip4/127.0.0.1/tcp/53337") let ma: MultiAddress = Multiaddress.init("/ip4/127.0.0.1/tcp/53337")
let transport: TcpTransport = newTransport(TcpTransport, ma) let transport: TcpTransport = newTransport(TcpTransport)
let conn = await transport.dial(ma) let conn = await transport.dial(ma)
let msg = await conn.read(6) let msg = await conn.read(6)
result = cast[string](msg) == "Hello!" result = cast[string](msg) == "Hello!"
@ -65,7 +65,7 @@ suite "TCP transport suite":
await server.join() await server.join()
check waitFor(testDialer(initTAddress("127.0.0.1:53337"))) == true check waitFor(testDialer(initTAddress("127.0.0.1:53337"))) == true
test "test dialer: handle write": test "test dialer: handle write":
proc testDialer(address: TransportAddress): Future[bool] {.async.} = proc testDialer(address: TransportAddress): Future[bool] {.async.} =
proc serveClient(server: StreamServer, proc serveClient(server: StreamServer,
transp: StreamTransport) {.async.} = transp: StreamTransport) {.async.} =
@ -82,7 +82,7 @@ test "test dialer: handle write":
server.start() server.start()
let ma: MultiAddress = Multiaddress.init("/ip4/127.0.0.1/tcp/53337") let ma: MultiAddress = Multiaddress.init("/ip4/127.0.0.1/tcp/53337")
let transport: TcpTransport = newTransport(TcpTransport, ma) let transport: TcpTransport = newTransport(TcpTransport)
let conn = await transport.dial(ma) let conn = await transport.dial(ma)
await conn.write(cstring("Hello!"), 6) await conn.write(cstring("Hello!"), 6)
result = true result = true
@ -91,3 +91,42 @@ test "test dialer: handle write":
server.close() server.close()
await server.join() await server.join()
check waitFor(testDialer(initTAddress("127.0.0.1:53337"))) == true check waitFor(testDialer(initTAddress("127.0.0.1:53337"))) == true
test "test listener - dialer: handle write":
proc testListenerDialer(): Future[bool] {.async.} =
let ma: MultiAddress = Multiaddress.init("/ip4/127.0.0.1/tcp/53339")
proc connHandler(conn: Connection): Future[void] {.async ,gcsafe.} =
result = conn.write(cstring("Hello!"), 6)
await conn.close()
let transport1: TcpTransport = newTransport(TcpTransport)
await transport1.listen(ma, connHandler)
let transport2: TcpTransport = newTransport(TcpTransport)
let conn = await transport2.dial(ma)
let msg = await conn.read(6)
await transport1.close()
result = cast[string](msg) == "Hello!"
check:
waitFor(testListenerDialer()) == true
test "test listener - dialer: handle read":
proc testListenerDialer(): Future[bool] {.async.} =
let ma: MultiAddress = Multiaddress.init("/ip4/127.0.0.1/tcp/53340")
proc connHandler(conn: Connection): Future[void] {.async ,gcsafe.} =
let msg = await conn.read(6)
check cast[string](msg) == "Hello!"
let transport1: TcpTransport = newTransport(TcpTransport)
await transport1.listen(ma, connHandler)
let transport2: TcpTransport = newTransport(TcpTransport)
let conn = await transport2.dial(ma)
await conn.write(cstring("Hello!"), 6)
await transport1.close()
result = true
check:
waitFor(testListenerDialer()) == true