mirror of
https://github.com/logos-messaging/logos-messaging-nim.git
synced 2026-01-02 14:03:06 +00:00
114 lines
2.8 KiB
Nim
114 lines
2.8 KiB
Nim
{.used.}
|
|
|
|
import testutils/unittests, chronos, libp2p/crypto/crypto
|
|
|
|
import
|
|
waku/[
|
|
common/paging,
|
|
node/peer_manager,
|
|
waku_core,
|
|
waku_store_legacy,
|
|
waku_store_legacy/client,
|
|
],
|
|
../testlib/wakucore,
|
|
./store_utils
|
|
|
|
suite "Waku Store - query handler legacy":
|
|
asyncTest "history query handler should be called":
|
|
## Setup
|
|
let
|
|
serverSwitch = newTestSwitch()
|
|
clientSwitch = newTestSwitch()
|
|
|
|
await allFutures(serverSwitch.start(), clientSwitch.start())
|
|
|
|
## Given
|
|
let serverPeerInfo = serverSwitch.peerInfo.toRemotePeerInfo()
|
|
|
|
let msg = fakeWakuMessage(contentTopic = DefaultContentTopic)
|
|
|
|
var queryHandlerFut = newFuture[(HistoryQuery)]()
|
|
|
|
let queryHandler = proc(
|
|
req: HistoryQuery
|
|
): Future[HistoryResult] {.async, gcsafe.} =
|
|
queryHandlerFut.complete(req)
|
|
return ok(HistoryResponse(messages: @[msg]))
|
|
|
|
let
|
|
server = await newTestWakuStore(serverSwitch, handler = queryhandler)
|
|
client = newTestWakuStoreClient(clientSwitch)
|
|
|
|
let req = HistoryQuery(
|
|
contentTopics: @[DefaultContentTopic],
|
|
direction: PagingDirection.FORWARD,
|
|
requestId: "reqId",
|
|
)
|
|
|
|
## When
|
|
let queryRes = await client.query(req, peer = serverPeerInfo)
|
|
|
|
## Then
|
|
check:
|
|
not queryHandlerFut.failed()
|
|
queryRes.isOk()
|
|
|
|
let request = queryHandlerFut.read()
|
|
check:
|
|
request == req
|
|
|
|
let response = queryRes.tryGet()
|
|
check:
|
|
response.messages.len == 1
|
|
response.messages == @[msg]
|
|
|
|
## Cleanup
|
|
await allFutures(serverSwitch.stop(), clientSwitch.stop())
|
|
|
|
asyncTest "history query handler should be called and return an error":
|
|
## Setup
|
|
let
|
|
serverSwitch = newTestSwitch()
|
|
clientSwitch = newTestSwitch()
|
|
|
|
await allFutures(serverSwitch.start(), clientSwitch.start())
|
|
|
|
## Given
|
|
let serverPeerInfo = serverSwitch.peerInfo.toRemotePeerInfo()
|
|
|
|
var queryHandlerFut = newFuture[(HistoryQuery)]()
|
|
let queryHandler = proc(
|
|
req: HistoryQuery
|
|
): Future[HistoryResult] {.async, gcsafe.} =
|
|
queryHandlerFut.complete(req)
|
|
return err(HistoryError(kind: HistoryErrorKind.BAD_REQUEST))
|
|
|
|
let
|
|
server = await newTestWakuStore(serverSwitch, handler = queryhandler)
|
|
client = newTestWakuStoreClient(clientSwitch)
|
|
|
|
let req = HistoryQuery(
|
|
contentTopics: @[DefaultContentTopic],
|
|
direction: PagingDirection.FORWARD,
|
|
requestId: "reqId",
|
|
)
|
|
|
|
## When
|
|
let queryRes = await client.query(req, peer = serverPeerInfo)
|
|
|
|
## Then
|
|
check:
|
|
not queryHandlerFut.failed()
|
|
queryRes.isErr()
|
|
|
|
let request = queryHandlerFut.read()
|
|
check:
|
|
request == req
|
|
|
|
let error = queryRes.tryError()
|
|
check:
|
|
error.kind == HistoryErrorKind.BAD_REQUEST
|
|
|
|
## Cleanup
|
|
await allFutures(serverSwitch.stop(), clientSwitch.stop())
|