2020-08-31 05:32:41 +02:00
|
|
|
{.used.}
|
2020-08-27 04:44:09 +02:00
|
|
|
|
2020-08-31 05:32:41 +02:00
|
|
|
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,
|
2020-09-07 13:26:32 +02:00
|
|
|
../../waku/protocol/v2/[waku_store, message_notifier],
|
2020-08-31 05:32:41 +02:00
|
|
|
../test_helpers, ./utils
|
2020-08-27 04:44:09 +02:00
|
|
|
|
|
|
|
procSuite "Waku Store":
|
|
|
|
asyncTest "handle query":
|
|
|
|
let
|
|
|
|
proto = WakuStore.init()
|
2020-09-07 13:26:32 +02:00
|
|
|
subscription = proto.subscription()
|
2020-08-27 04:44:09 +02:00
|
|
|
|
2020-09-07 13:26:32 +02:00
|
|
|
var subscriptions = initTable[string, MessageNotificationSubscription]()
|
|
|
|
subscriptions["test"] = subscription
|
2020-08-27 04:44:09 +02:00
|
|
|
|
|
|
|
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)
|
|
|
|
|
2020-09-07 13:26:32 +02:00
|
|
|
subscriptions.notify(msg)
|
|
|
|
subscriptions.notify(msg2)
|
2020-08-27 04:44:09 +02:00
|
|
|
|
|
|
|
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)
|
|
|
|
|
2020-09-10 13:16:31 +02:00
|
|
|
var rpc = HistoryQuery(uuid: "1234", topics: @["topic"])
|
2020-08-27 04:44:09 +02:00
|
|
|
discard await msDial.select(conn, WakuStoreCodec)
|
|
|
|
await conn.writeLP(rpc.encode().buffer)
|
|
|
|
|
|
|
|
var message = await conn.readLp(64*1024)
|
2020-09-10 13:16:31 +02:00
|
|
|
let response = HistoryResponse.init(message)
|
2020-08-27 04:44:09 +02:00
|
|
|
|
|
|
|
check:
|
|
|
|
response.isErr == false
|
2020-09-10 13:16:31 +02:00
|
|
|
response.value.uuid == rpc.uuid
|
|
|
|
response.value.messages.len() == 1
|
|
|
|
response.value.messages[0] == msg
|