2022-10-20 16:47:08 +00:00
|
|
|
{.used.}
|
|
|
|
|
|
|
|
import
|
2022-10-24 09:08:51 +00:00
|
|
|
std/[options, tables, sets],
|
2022-10-20 16:47:08 +00:00
|
|
|
testutils/unittests,
|
|
|
|
chronos,
|
|
|
|
chronicles,
|
|
|
|
libp2p/crypto/crypto
|
|
|
|
import
|
|
|
|
../../waku/v2/protocol/waku_message,
|
|
|
|
../../waku/v2/protocol/waku_store,
|
|
|
|
../../waku/v2/protocol/waku_store/client,
|
|
|
|
../../waku/v2/protocol/waku_store/protocol_metrics,
|
|
|
|
../../waku/v2/node/storage/sqlite,
|
|
|
|
../../waku/v2/node/storage/message/sqlite_store,
|
|
|
|
../../waku/v2/node/peer_manager/peer_manager,
|
2022-10-24 09:08:51 +00:00
|
|
|
./testlib/common,
|
|
|
|
./testlib/switch
|
2022-10-20 16:47:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
proc newTestDatabase(): SqliteDatabase =
|
|
|
|
SqliteDatabase.init("", inMemory = true).tryGet()
|
|
|
|
|
|
|
|
proc newTestStore(): MessageStore =
|
|
|
|
let database = newTestDatabase()
|
|
|
|
SqliteStore.init(database).tryGet()
|
|
|
|
|
2022-10-24 09:08:51 +00:00
|
|
|
proc newTestWakuStore(switch: Switch, store=newTestStore()): Future[WakuStore] {.async.} =
|
2022-10-20 16:47:08 +00:00
|
|
|
let
|
|
|
|
peerManager = PeerManager.new(switch)
|
|
|
|
rng = crypto.newRng()
|
|
|
|
proto = WakuStore.init(peerManager, rng, store)
|
|
|
|
|
2022-10-24 09:08:51 +00:00
|
|
|
await proto.start()
|
2022-10-20 16:47:08 +00:00
|
|
|
switch.mount(proto)
|
|
|
|
|
|
|
|
return proto
|
|
|
|
|
|
|
|
proc newTestWakuStoreClient(switch: Switch, store: MessageStore = nil): WakuStoreClient =
|
|
|
|
let
|
|
|
|
peerManager = PeerManager.new(switch)
|
|
|
|
rng = crypto.newRng()
|
|
|
|
WakuStoreClient.new(peerManager, rng, store)
|
|
|
|
|
|
|
|
|
|
|
|
procSuite "Waku Store Client":
|
|
|
|
|
|
|
|
## Fixtures
|
|
|
|
let testStore = block:
|
|
|
|
let store = newTestStore()
|
|
|
|
let msgList = @[
|
|
|
|
fakeWakuMessage(payload= @[byte 0], contentTopic=ContentTopic("0")),
|
|
|
|
fakeWakuMessage(payload= @[byte 1], contentTopic=DefaultContentTopic),
|
|
|
|
fakeWakuMessage(payload= @[byte 2], contentTopic=DefaultContentTopic),
|
|
|
|
fakeWakuMessage(payload= @[byte 3], contentTopic=DefaultContentTopic),
|
|
|
|
fakeWakuMessage(payload= @[byte 4], contentTopic=DefaultContentTopic),
|
|
|
|
fakeWakuMessage(payload= @[byte 5], contentTopic=DefaultContentTopic),
|
|
|
|
fakeWakuMessage(payload= @[byte 6], contentTopic=DefaultContentTopic),
|
|
|
|
fakeWakuMessage(payload= @[byte 7], contentTopic=DefaultContentTopic),
|
|
|
|
fakeWakuMessage(payload= @[byte 8], contentTopic=DefaultContentTopic),
|
|
|
|
fakeWakuMessage(payload= @[byte 9], contentTopic=ContentTopic("9")),
|
|
|
|
fakeWakuMessage(payload= @[byte 10], contentTopic=DefaultContentTopic),
|
|
|
|
fakeWakuMessage(payload= @[byte 11], contentTopic=ContentTopic("11")),
|
|
|
|
fakeWakuMessage(payload= @[byte 12], contentTopic=DefaultContentTopic),
|
|
|
|
]
|
|
|
|
|
|
|
|
for msg in msgList:
|
|
|
|
assert store.put(DefaultPubsubTopic, msg).isOk()
|
|
|
|
|
|
|
|
store
|
|
|
|
|
|
|
|
asyncTest "single query to peer":
|
|
|
|
## Setup
|
|
|
|
let
|
|
|
|
serverSwitch = newTestSwitch()
|
|
|
|
clientSwitch = newTestSwitch()
|
|
|
|
|
|
|
|
await allFutures(serverSwitch.start(), clientSwitch.start())
|
|
|
|
|
|
|
|
let
|
2022-10-24 09:08:51 +00:00
|
|
|
server = await newTestWakuStore(serverSwitch, store=testStore)
|
2022-10-20 16:47:08 +00:00
|
|
|
client = newTestWakuStoreClient(clientSwitch)
|
|
|
|
|
|
|
|
## Given
|
|
|
|
let peer = serverSwitch.peerInfo.toRemotePeerInfo()
|
|
|
|
let rpc = HistoryQuery(
|
|
|
|
contentFilters: @[HistoryContentFilter(contentTopic: DefaultContentTopic)],
|
|
|
|
pagingInfo: PagingInfo(pageSize: 8)
|
|
|
|
)
|
|
|
|
|
|
|
|
## When
|
|
|
|
let res = await client.query(rpc, peer)
|
|
|
|
|
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
res.isOk()
|
|
|
|
|
|
|
|
let response = res.tryGet()
|
|
|
|
check:
|
|
|
|
## No pagination specified. Response will be auto-paginated with
|
|
|
|
## up to MaxPageSize messages per page.
|
|
|
|
response.messages.len() == 8
|
|
|
|
response.pagingInfo != PagingInfo()
|
|
|
|
|
|
|
|
## Cleanup
|
|
|
|
await allFutures(clientSwitch.stop(), serverSwitch.stop())
|
|
|
|
|
|
|
|
asyncTest "multiple query to peer with pagination":
|
|
|
|
## Setup
|
|
|
|
let
|
|
|
|
serverSwitch = newTestSwitch()
|
|
|
|
clientSwitch = newTestSwitch()
|
|
|
|
|
|
|
|
await allFutures(serverSwitch.start(), clientSwitch.start())
|
|
|
|
|
|
|
|
let
|
2022-10-24 09:08:51 +00:00
|
|
|
server = await newTestWakuStore(serverSwitch, store=testStore)
|
2022-10-20 16:47:08 +00:00
|
|
|
client = newTestWakuStoreClient(clientSwitch)
|
|
|
|
|
|
|
|
## Given
|
|
|
|
let peer = serverSwitch.peerInfo.toRemotePeerInfo()
|
|
|
|
let rpc = HistoryQuery(
|
|
|
|
contentFilters: @[HistoryContentFilter(contentTopic: DefaultContentTopic)],
|
|
|
|
pagingInfo: PagingInfo(pageSize: 5)
|
|
|
|
)
|
|
|
|
|
|
|
|
## When
|
|
|
|
let res = await client.queryWithPaging(rpc, peer)
|
|
|
|
|
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
res.isOk()
|
|
|
|
|
|
|
|
let response = res.tryGet()
|
|
|
|
check:
|
|
|
|
response.len == 10
|
|
|
|
|
|
|
|
## Cleanup
|
|
|
|
await allFutures(clientSwitch.stop(), serverSwitch.stop())
|
|
|
|
|
|
|
|
asyncTest "multiple query to multiple peers with pagination":
|
|
|
|
## Setup
|
|
|
|
let
|
|
|
|
serverSwitchA = newTestSwitch()
|
|
|
|
serverSwitchB = newTestSwitch()
|
|
|
|
clientSwitch = newTestSwitch()
|
|
|
|
|
|
|
|
await allFutures(serverSwitchA.start(), serverSwitchB.start(), clientSwitch.start())
|
|
|
|
|
|
|
|
let
|
2022-10-24 09:08:51 +00:00
|
|
|
serverA = await newTestWakuStore(serverSwitchA, store=testStore)
|
|
|
|
serverB = await newTestWakuStore(serverSwitchB, store=testStore)
|
2022-10-20 16:47:08 +00:00
|
|
|
client = newTestWakuStoreClient(clientSwitch)
|
|
|
|
|
|
|
|
## Given
|
|
|
|
let peers = @[
|
|
|
|
serverSwitchA.peerInfo.toRemotePeerInfo(),
|
|
|
|
serverSwitchB.peerInfo.toRemotePeerInfo()
|
|
|
|
]
|
|
|
|
let rpc = HistoryQuery(
|
|
|
|
contentFilters: @[HistoryContentFilter(contentTopic: DefaultContentTopic)],
|
|
|
|
pagingInfo: PagingInfo(pageSize: 5)
|
|
|
|
)
|
|
|
|
|
|
|
|
## When
|
|
|
|
let res = await client.queryLoop(rpc, peers)
|
|
|
|
|
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
res.isOk()
|
|
|
|
|
|
|
|
let response = res.tryGet()
|
|
|
|
check:
|
|
|
|
response.len == 10
|
|
|
|
|
|
|
|
## Cleanup
|
|
|
|
await allFutures(clientSwitch.stop(), serverSwitchA.stop(), serverSwitchB.stop())
|
|
|
|
|
|
|
|
asyncTest "single query with no pre-configured store peer should fail":
|
|
|
|
## Setup
|
|
|
|
let
|
|
|
|
serverSwitch = newTestSwitch()
|
|
|
|
clientSwitch = newTestSwitch()
|
|
|
|
|
|
|
|
await allFutures(serverSwitch.start(), clientSwitch.start())
|
|
|
|
|
|
|
|
let
|
2022-10-24 09:08:51 +00:00
|
|
|
server = await newTestWakuStore(serverSwitch, store=testStore)
|
2022-10-20 16:47:08 +00:00
|
|
|
client = newTestWakuStoreClient(clientSwitch)
|
|
|
|
|
|
|
|
## Given
|
|
|
|
let rpc = HistoryQuery(
|
|
|
|
contentFilters: @[HistoryContentFilter(contentTopic: DefaultContentTopic)],
|
|
|
|
pagingInfo: PagingInfo(pageSize: 8)
|
|
|
|
)
|
|
|
|
|
|
|
|
## When
|
|
|
|
let res = await client.query(rpc)
|
|
|
|
|
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
res.isErr()
|
|
|
|
res.error == peerNotFoundFailure
|
|
|
|
|
|
|
|
## Cleanup
|
|
|
|
await allFutures(clientSwitch.stop(), serverSwitch.stop())
|
|
|
|
|
|
|
|
asyncTest "single query to pre-configured store peer":
|
|
|
|
## Setup
|
|
|
|
let
|
|
|
|
serverSwitch = newTestSwitch()
|
|
|
|
clientSwitch = newTestSwitch()
|
|
|
|
|
|
|
|
await allFutures(serverSwitch.start(), clientSwitch.start())
|
|
|
|
|
|
|
|
let
|
2022-10-24 09:08:51 +00:00
|
|
|
server = await newTestWakuStore(serverSwitch, store=testStore)
|
2022-10-20 16:47:08 +00:00
|
|
|
client = newTestWakuStoreClient(clientSwitch)
|
|
|
|
|
|
|
|
## Given
|
|
|
|
let peer = serverSwitch.peerInfo.toRemotePeerInfo()
|
|
|
|
let rpc = HistoryQuery(
|
|
|
|
contentFilters: @[HistoryContentFilter(contentTopic: DefaultContentTopic)],
|
|
|
|
pagingInfo: PagingInfo(pageSize: 8)
|
|
|
|
)
|
|
|
|
|
|
|
|
## When
|
|
|
|
client.setPeer(peer)
|
|
|
|
|
|
|
|
let res = await client.query(rpc)
|
|
|
|
|
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
res.isOk()
|
|
|
|
|
|
|
|
let response = res.tryGet()
|
|
|
|
check:
|
|
|
|
## No pagination specified. Response will be auto-paginated with
|
|
|
|
## up to MaxPageSize messages per page.
|
|
|
|
response.messages.len() == 8
|
|
|
|
response.pagingInfo != PagingInfo()
|
|
|
|
|
|
|
|
## Cleanup
|
|
|
|
await allFutures(clientSwitch.stop(), serverSwitch.stop())
|