mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-10 23:06:34 +00:00
ddcfc3fdd6
* Cleanup of warnings + imports, etc. * Remove connected_peers metric as there is already libp2p_pubsub_peers
84 lines
2.5 KiB
Nim
84 lines
2.5 KiB
Nim
{.used.}
|
|
|
|
import
|
|
std/[unittest, options, tables, sets],
|
|
chronos, chronicles,
|
|
libp2p/switch,
|
|
libp2p/protobuf/minprotobuf,
|
|
libp2p/stream/[bufferstream, connection],
|
|
libp2p/crypto/crypto,
|
|
libp2p/protocols/pubsub/rpc/message,
|
|
libp2p/multistream,
|
|
libp2p/transports/transport,
|
|
libp2p/transports/tcptransport,
|
|
../../waku/protocol/v2/[waku_store, filter],
|
|
../test_helpers, ./utils
|
|
|
|
procSuite "Waku Store":
|
|
|
|
test "encoding and decoding StoreRPC":
|
|
let
|
|
peer = PeerInfo.init(PrivateKey.random(ECDSA, rng[]).get())
|
|
msg = Message.init(peer, @[byte 1, 2, 3], "topic", 3, false)
|
|
|
|
rpc = StoreRPC(query: @[HistoryQuery(uuid: "1", topics: @["foo"])], response: @[HistoryResponse(uuid: "1", messages: @[msg])])
|
|
|
|
let buf = rpc.encode()
|
|
|
|
let decode = StoreRPC.init(buf.buffer)
|
|
|
|
check:
|
|
decode.isErr == false
|
|
decode.value == rpc
|
|
|
|
asyncTest "handle query":
|
|
let
|
|
proto = WakuStore.init()
|
|
filter = proto.filter()
|
|
|
|
var filters = initTable[string, Filter]()
|
|
filters["test"] = filter
|
|
|
|
let
|
|
peer = PeerInfo.init(PrivateKey.random(ECDSA, rng[]).get())
|
|
msg = Message.init(peer, @[byte 1, 2, 3], "topic", 3, false)
|
|
msg2 = Message.init(peer, @[byte 1, 2, 3], "topic2", 4, false)
|
|
|
|
filters.notify(msg)
|
|
filters.notify(msg2)
|
|
|
|
let ma: MultiAddress = Multiaddress.init("/ip4/0.0.0.0/tcp/0").tryGet()
|
|
let remoteSecKey = PrivateKey.random(ECDSA, rng[]).get()
|
|
let remotePeerInfo = PeerInfo.init(
|
|
remoteSecKey,
|
|
[ma],
|
|
["/test/proto1/1.0.0", "/test/proto2/1.0.0"]
|
|
)
|
|
|
|
var serverFut: Future[void]
|
|
let msListen = newMultistream()
|
|
|
|
msListen.addHandler(WakuStoreCodec, proto)
|
|
proc connHandler(conn: Connection): Future[void] {.async, gcsafe.} =
|
|
await msListen.handle(conn)
|
|
|
|
var transport1 = TcpTransport.init()
|
|
serverFut = await transport1.listen(ma, connHandler)
|
|
|
|
let msDial = newMultistream()
|
|
let transport2: TcpTransport = TcpTransport.init()
|
|
let conn = await transport2.dial(transport1.ma)
|
|
|
|
var rpc = StoreRPC(query: @[HistoryQuery(uuid: "1234", topics: @["topic"])])
|
|
discard await msDial.select(conn, WakuStoreCodec)
|
|
await conn.writeLP(rpc.encode().buffer)
|
|
|
|
var message = await conn.readLp(64*1024)
|
|
let response = StoreRPC.init(message)
|
|
|
|
check:
|
|
response.isErr == false
|
|
response.value.response[0].uuid == rpc.query[0].uuid
|
|
response.value.response[0].messages.len() == 1
|
|
response.value.response[0].messages[0] == msg
|