2021-03-23 08:24:09 +00:00
|
|
|
{.used.}
|
|
|
|
|
2020-12-21 11:45:07 +00:00
|
|
|
import
|
2022-09-21 17:03:54 +00:00
|
|
|
std/[options, tables, sets, times],
|
|
|
|
stew/byteutils,
|
|
|
|
stew/shims/net as stewNet,
|
2021-03-26 10:21:52 +00:00
|
|
|
testutils/unittests,
|
2022-09-21 17:03:54 +00:00
|
|
|
chronos,
|
|
|
|
chronicles,
|
2020-12-21 11:45:07 +00:00
|
|
|
libp2p/switch,
|
|
|
|
libp2p/protobuf/minprotobuf,
|
|
|
|
libp2p/stream/[bufferstream, connection],
|
|
|
|
libp2p/crypto/[crypto, secp],
|
|
|
|
libp2p/switch,
|
2022-09-20 10:16:14 +00:00
|
|
|
eth/keys
|
|
|
|
import
|
2021-07-13 07:36:23 +00:00
|
|
|
../../waku/v2/protocol/waku_message,
|
2022-08-01 11:31:00 +00:00
|
|
|
../../waku/v2/protocol/waku_store,
|
2020-12-21 11:45:07 +00:00
|
|
|
../../waku/v2/protocol/waku_swap/waku_swap,
|
2022-09-20 10:16:14 +00:00
|
|
|
../../waku/v2/node/storage/message/waku_store_queue,
|
2020-12-21 11:45:07 +00:00
|
|
|
../../waku/v2/node/wakunode2,
|
2021-10-06 13:10:43 +00:00
|
|
|
../../waku/v2/utils/peers,
|
2022-09-21 17:03:54 +00:00
|
|
|
../../waku/v2/utils/time,
|
|
|
|
../test_helpers,
|
|
|
|
./utils
|
|
|
|
|
|
|
|
|
|
|
|
const
|
|
|
|
DefaultPubsubTopic = "/waku/2/default-waku/proto"
|
|
|
|
DefaultContentTopic = ContentTopic("/waku/2/default-content/proto")
|
|
|
|
|
|
|
|
|
|
|
|
proc now(): Timestamp =
|
|
|
|
getNanosecondTime(getTime().toUnixFloat())
|
|
|
|
|
|
|
|
proc fakeWakuMessage(
|
|
|
|
payload = "TEST-PAYLOAD",
|
|
|
|
contentTopic = DefaultContentTopic,
|
|
|
|
ts = now()
|
|
|
|
): WakuMessage =
|
|
|
|
WakuMessage(
|
|
|
|
payload: toBytes(payload),
|
|
|
|
contentTopic: contentTopic,
|
|
|
|
version: 1,
|
|
|
|
timestamp: ts
|
|
|
|
)
|
|
|
|
|
2020-12-21 11:45:07 +00:00
|
|
|
|
|
|
|
procSuite "Waku SWAP Accounting":
|
|
|
|
test "Handshake Encode/Decode":
|
|
|
|
let
|
|
|
|
beneficiary = @[byte 0, 1, 2]
|
|
|
|
handshake = Handshake(beneficiary: beneficiary)
|
|
|
|
pb = handshake.encode()
|
|
|
|
|
|
|
|
let decodedHandshake = Handshake.init(pb.buffer)
|
|
|
|
|
|
|
|
check:
|
|
|
|
decodedHandshake.isErr == false
|
|
|
|
decodedHandshake.get().beneficiary == beneficiary
|
|
|
|
|
|
|
|
test "Cheque Encode/Decode":
|
|
|
|
let
|
|
|
|
amount = 1'u32
|
|
|
|
date = 9000'u32
|
|
|
|
beneficiary = @[byte 0, 1, 2]
|
|
|
|
cheque = Cheque(beneficiary: beneficiary, amount: amount, date: date)
|
|
|
|
pb = cheque.encode()
|
|
|
|
|
|
|
|
let decodedCheque = Cheque.init(pb.buffer)
|
|
|
|
|
|
|
|
check:
|
|
|
|
decodedCheque.isErr == false
|
|
|
|
decodedCheque.get() == cheque
|
|
|
|
|
2021-03-01 06:17:28 +00:00
|
|
|
# TODO To do this reliably we need access to contract node
|
|
|
|
# With current logic state isn't updated because of bad cheque
|
|
|
|
# Consider moving this test to e2e test, and/or move swap module to be on by default
|
2020-12-21 11:45:07 +00:00
|
|
|
asyncTest "Update accounting state after store operations":
|
2022-09-21 17:03:54 +00:00
|
|
|
## Setup
|
2020-12-21 11:45:07 +00:00
|
|
|
let
|
2022-09-21 17:03:54 +00:00
|
|
|
serverKey = crypto.PrivateKey.random(Secp256k1, rng[])[]
|
|
|
|
server = WakuNode.new(serverKey, ValidIpAddress.init("0.0.0.0"), Port(60002))
|
|
|
|
clientKey = crypto.PrivateKey.random(Secp256k1, rng[])[]
|
|
|
|
client = WakuNode.new(clientKey, ValidIpAddress.init("0.0.0.0"), Port(60000))
|
2020-12-21 11:45:07 +00:00
|
|
|
|
|
|
|
# Start nodes and mount protocols
|
2022-09-21 17:03:54 +00:00
|
|
|
await allFutures(client.start(), server.start())
|
|
|
|
await server.mountSwap()
|
|
|
|
await server.mountStore(store=StoreQueueRef.new())
|
|
|
|
await client.mountSwap()
|
|
|
|
await client.mountStore()
|
|
|
|
|
|
|
|
client.wakuStore.setPeer(server.peerInfo.toRemotePeerInfo())
|
|
|
|
client.wakuSwap.setPeer(server.peerInfo.toRemotePeerInfo())
|
|
|
|
server.wakuSwap.setPeer(client.peerInfo.toRemotePeerInfo())
|
|
|
|
|
|
|
|
## Given
|
|
|
|
let message = fakeWakuMessage()
|
2020-12-21 11:45:07 +00:00
|
|
|
|
2022-09-21 17:03:54 +00:00
|
|
|
server.wakuStore.handleMessage(DefaultPubsubTopic, message)
|
2020-12-21 11:45:07 +00:00
|
|
|
|
2022-09-21 17:03:54 +00:00
|
|
|
## When
|
|
|
|
let queryRes = await client.query(HistoryQuery(contentFilters: @[HistoryContentFilter(contentTopic: DefaultContentTopic)]))
|
2020-12-21 11:45:07 +00:00
|
|
|
|
2022-09-21 17:03:54 +00:00
|
|
|
## Then
|
|
|
|
check queryRes.isOk()
|
2020-12-21 11:45:07 +00:00
|
|
|
|
2022-09-21 17:03:54 +00:00
|
|
|
let response = queryRes.get()
|
|
|
|
check:
|
|
|
|
response.messages == @[message]
|
2020-12-21 11:45:07 +00:00
|
|
|
|
|
|
|
check:
|
2022-09-21 17:03:54 +00:00
|
|
|
client.wakuSwap.accounting[server.peerInfo.peerId] == 1
|
|
|
|
server.wakuSwap.accounting[client.peerInfo.peerId] == -1
|
|
|
|
|
|
|
|
## Cleanup
|
|
|
|
await allFutures(client.stop(), server.stop())
|
|
|
|
|
2020-12-21 11:45:07 +00:00
|
|
|
|
2021-06-15 02:28:14 +00:00
|
|
|
# This test will only Be checked if in Mock mode
|
2022-09-21 17:03:54 +00:00
|
|
|
# TODO: Add cheque here
|
2021-06-15 02:28:14 +00:00
|
|
|
asyncTest "Update accounting state after sending cheque":
|
2022-09-21 17:03:54 +00:00
|
|
|
## Setup
|
2021-06-15 02:28:14 +00:00
|
|
|
let
|
2022-09-21 17:03:54 +00:00
|
|
|
serverKey = crypto.PrivateKey.random(Secp256k1, rng[])[]
|
|
|
|
server = WakuNode.new(serverKey, ValidIpAddress.init("0.0.0.0"), Port(60002))
|
|
|
|
clientKey = crypto.PrivateKey.random(Secp256k1, rng[])[]
|
|
|
|
client = WakuNode.new(clientKey, ValidIpAddress.init("0.0.0.0"), Port(60000))
|
|
|
|
|
2021-06-15 02:28:14 +00:00
|
|
|
# Define the waku swap Config for this test
|
|
|
|
let swapConfig = SwapConfig(mode: SwapMode.Mock, paymentThreshold: 1, disconnectThreshold: -1)
|
|
|
|
|
|
|
|
# Start nodes and mount protocols
|
2022-09-21 17:03:54 +00:00
|
|
|
await allFutures(client.start(), server.start())
|
|
|
|
await server.mountSwap(swapConfig)
|
|
|
|
await server.mountStore(store=StoreQueueRef.new())
|
|
|
|
await client.mountSwap(swapConfig)
|
|
|
|
await client.mountStore()
|
|
|
|
|
|
|
|
client.wakuStore.setPeer(server.peerInfo.toRemotePeerInfo())
|
|
|
|
client.wakuSwap.setPeer(server.peerInfo.toRemotePeerInfo())
|
|
|
|
server.wakuSwap.setPeer(client.peerInfo.toRemotePeerInfo())
|
|
|
|
|
|
|
|
## Given
|
|
|
|
let message = fakeWakuMessage()
|
2021-06-15 02:28:14 +00:00
|
|
|
|
2022-09-21 17:03:54 +00:00
|
|
|
server.wakuStore.handleMessage(DefaultPubsubTopic, message)
|
2021-06-15 02:28:14 +00:00
|
|
|
|
2022-09-21 17:03:54 +00:00
|
|
|
## When
|
|
|
|
# TODO: Handshakes - for now we assume implicit, e2e still works for PoC
|
|
|
|
let res1 = await client.query(HistoryQuery(contentFilters: @[HistoryContentFilter(contentTopic: DefaultContentTopic)]))
|
|
|
|
let res2 = await client.query(HistoryQuery(contentFilters: @[HistoryContentFilter(contentTopic: DefaultContentTopic)]))
|
2021-06-15 02:28:14 +00:00
|
|
|
|
2022-09-21 17:03:54 +00:00
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
res1.isOk()
|
|
|
|
res2.isOk()
|
2021-06-15 02:28:14 +00:00
|
|
|
|
|
|
|
check:
|
|
|
|
# Accounting table updated with credit and debit, respectively
|
|
|
|
# After sending a cheque the balance is partially adjusted
|
2022-09-21 17:03:54 +00:00
|
|
|
client.wakuSwap.accounting[server.peerInfo.peerId] == 1
|
|
|
|
server.wakuSwap.accounting[client.peerInfo.peerId] == -1
|
|
|
|
|
|
|
|
## Cleanup
|
|
|
|
await allFutures(client.stop(), server.stop())
|