2020-08-31 03:32:41 +00:00
|
|
|
{.used.}
|
2020-08-27 02:44:09 +00:00
|
|
|
|
2024-03-15 23:08:47 +00:00
|
|
|
import std/options, testutils/unittests, chronos, chronicles, libp2p/crypto/crypto
|
2023-11-27 17:33:27 +00:00
|
|
|
|
2022-07-25 11:01:37 +00:00
|
|
|
import
|
2024-04-25 13:09:52 +00:00
|
|
|
../../../waku/[
|
|
|
|
common/paging,
|
|
|
|
node/peer_manager,
|
|
|
|
waku_core,
|
|
|
|
waku_core/message/digest,
|
|
|
|
waku_store,
|
|
|
|
waku_store/client,
|
|
|
|
waku_store/common,
|
|
|
|
],
|
2024-03-15 23:08:47 +00:00
|
|
|
../testlib/[common, wakucore],
|
2023-11-27 17:33:27 +00:00
|
|
|
./store_utils
|
2022-10-20 16:09:40 +00:00
|
|
|
|
2022-11-21 10:16:57 +00:00
|
|
|
suite "Waku Store - query handler":
|
|
|
|
asyncTest "history query handler should be called":
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2022-11-21 10:16:57 +00:00
|
|
|
## Setup
|
|
|
|
let
|
|
|
|
serverSwitch = newTestSwitch()
|
|
|
|
clientSwitch = newTestSwitch()
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
await allFutures(serverSwitch.start(), clientSwitch.start())
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
## Given
|
|
|
|
let serverPeerInfo = serverSwitch.peerInfo.toRemotePeerInfo()
|
|
|
|
|
2024-03-15 23:08:47 +00:00
|
|
|
let msg = fakeWakuMessage(contentTopic = DefaultContentTopic)
|
2024-04-25 13:09:52 +00:00
|
|
|
let hash = computeMessageHash(DefaultPubsubTopic, msg)
|
2024-05-08 19:35:56 +00:00
|
|
|
let kv = WakuMessageKeyValue(
|
|
|
|
messageHash: hash, message: some(msg), pubsubTopic: some(DefaultPubsubTopic)
|
|
|
|
)
|
2022-11-21 10:16:57 +00:00
|
|
|
|
2024-04-25 13:09:52 +00:00
|
|
|
var queryHandlerFut = newFuture[(StoreQueryRequest)]()
|
2023-05-25 15:34:34 +00:00
|
|
|
|
2024-03-15 23:08:47 +00:00
|
|
|
let queryHandler = proc(
|
2024-04-25 13:09:52 +00:00
|
|
|
req: StoreQueryRequest
|
|
|
|
): Future[StoreQueryResult] {.async, gcsafe.} =
|
|
|
|
var request = req
|
|
|
|
request.requestId = "" # Must remove the id for equality
|
|
|
|
queryHandlerFut.complete(request)
|
|
|
|
return ok(StoreQueryResponse(messages: @[kv]))
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
let
|
2024-03-15 23:08:47 +00:00
|
|
|
server = await newTestWakuStore(serverSwitch, handler = queryhandler)
|
2022-11-21 10:16:57 +00:00
|
|
|
client = newTestWakuStoreClient(clientSwitch)
|
|
|
|
|
2024-04-25 13:09:52 +00:00
|
|
|
let req = StoreQueryRequest(
|
|
|
|
contentTopics: @[DefaultContentTopic], paginationForward: PagingDirection.FORWARD
|
2024-03-15 23:08:47 +00:00
|
|
|
)
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
## When
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2024-03-15 23:08:47 +00:00
|
|
|
let queryRes = await client.query(req, peer = serverPeerInfo)
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
not queryHandlerFut.failed()
|
|
|
|
queryRes.isOk()
|
|
|
|
|
|
|
|
let request = queryHandlerFut.read()
|
|
|
|
check:
|
|
|
|
request == req
|
|
|
|
|
|
|
|
let response = queryRes.tryGet()
|
|
|
|
check:
|
|
|
|
response.messages.len == 1
|
2024-04-25 13:09:52 +00:00
|
|
|
response.messages == @[kv]
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
## Cleanup
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2022-11-21 10:16:57 +00:00
|
|
|
await allFutures(serverSwitch.stop(), clientSwitch.stop())
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
asyncTest "history query handler should be called and return an error":
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2022-11-21 10:16:57 +00:00
|
|
|
## Setup
|
|
|
|
let
|
|
|
|
serverSwitch = newTestSwitch()
|
|
|
|
clientSwitch = newTestSwitch()
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
await allFutures(serverSwitch.start(), clientSwitch.start())
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
## Given
|
|
|
|
let serverPeerInfo = serverSwitch.peerInfo.toRemotePeerInfo()
|
|
|
|
|
2024-04-25 13:09:52 +00:00
|
|
|
var queryHandlerFut = newFuture[(StoreQueryRequest)]()
|
2024-03-15 23:08:47 +00:00
|
|
|
let queryHandler = proc(
|
2024-04-25 13:09:52 +00:00
|
|
|
req: StoreQueryRequest
|
|
|
|
): Future[StoreQueryResult] {.async, gcsafe.} =
|
|
|
|
var request = req
|
|
|
|
request.requestId = "" # Must remove the id for equality
|
|
|
|
queryHandlerFut.complete(request)
|
|
|
|
return err(StoreError(kind: ErrorCode.BAD_REQUEST))
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
let
|
2024-03-15 23:08:47 +00:00
|
|
|
server = await newTestWakuStore(serverSwitch, handler = queryhandler)
|
2022-11-21 10:16:57 +00:00
|
|
|
client = newTestWakuStoreClient(clientSwitch)
|
|
|
|
|
2024-04-25 13:09:52 +00:00
|
|
|
let req = StoreQueryRequest(
|
|
|
|
contentTopics: @[DefaultContentTopic], paginationForward: PagingDirection.FORWARD
|
2024-03-15 23:08:47 +00:00
|
|
|
)
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
## When
|
2024-03-15 23:08:47 +00:00
|
|
|
let queryRes = await client.query(req, peer = serverPeerInfo)
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
not queryHandlerFut.failed()
|
|
|
|
queryRes.isErr()
|
|
|
|
|
|
|
|
let request = queryHandlerFut.read()
|
|
|
|
check:
|
|
|
|
request == req
|
|
|
|
|
|
|
|
let error = queryRes.tryError()
|
|
|
|
check:
|
2024-04-25 13:09:52 +00:00
|
|
|
error.kind == ErrorCode.BAD_REQUEST
|
2022-11-21 10:16:57 +00:00
|
|
|
|
|
|
|
## Cleanup
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|
2024-03-15 23:08:47 +00:00
|
|
|
await allFutures(serverSwitch.stop(), clientSwitch.stop())
|
2024-05-29 08:05:07 +00:00
|
|
|
info "check point" # log added to track flaky test
|