nim-json-rpc/tests/testserverclient.nim

35 lines
1.2 KiB
Nim
Raw Normal View History

2018-04-12 18:51:06 +01:00
import ../eth-rpc / rpcclient, ../eth-rpc / rpcserver,
asyncdispatch, json, unittest, tables
2018-03-02 11:46:59 +00:00
2018-04-11 15:34:49 +03:00
# REVIEW: I'd like to see some dummy implementations of RPC calls handled in async fashion.
2018-04-12 18:51:06 +01:00
proc myProc* {.rpc.} =
# Custom async RPC call
return %"Hello"
var srv = newRpcServer("")
# This is required to automatically register `myProc` to new servers
registerRpcs(srv)
2018-04-12 19:29:48 +01:00
asyncCheck srv.serve
2018-04-12 18:51:06 +01:00
# TODO: Avoid having to add procs twice, once for the ethprocs in newRpcServer,
# and again with the extra `myProc` rpc
2018-03-02 11:46:59 +00:00
when isMainModule:
# create on localhost, default port
2018-03-22 17:29:43 +00:00
suite "RPC":
proc main {.async.} =
var client = newRpcClient()
await client.connect("localhost", Port(8545))
var response: Response
2018-03-02 11:46:59 +00:00
2018-03-22 17:29:43 +00:00
test "Version":
response = waitFor client.web3_clientVersion(newJNull())
check response.result == %"Nimbus-RPC-Test"
test "SHA3":
response = waitFor client.web3_sha3(%"abc")
check response.result.getStr == "3A985DA74FE225B2045C172D6BD390BD855F086E3E9D525B46BFE24511431532"
2018-04-12 19:29:48 +01:00
test "Custom RPC":
response = waitFor client.call("myProc", %"abc")
check response.result.getStr == "Hello"
2018-04-11 20:08:48 +01:00
2018-03-22 17:29:43 +00:00
waitFor main()
2018-04-12 19:29:48 +01:00