2020-11-03 21:20:40 +01:00
|
|
|
{.used.}
|
|
|
|
|
|
|
|
import
|
2023-02-07 10:45:25 +01:00
|
|
|
testutils/unittests
|
|
|
|
import
|
2021-01-06 17:35:05 +08:00
|
|
|
../../waku/v2/protocol/waku_message,
|
2023-02-07 10:45:25 +01:00
|
|
|
../../waku/v2/utils/compat,
|
2023-02-13 11:43:49 +01:00
|
|
|
../../waku/v2/utils/time,
|
|
|
|
./testlib/common
|
2020-11-03 21:20:40 +01:00
|
|
|
|
2023-02-13 11:43:49 +01:00
|
|
|
suite "Waku Payload":
|
2020-11-03 21:20:40 +01:00
|
|
|
|
|
|
|
test "Encode/Decode without encryption (version 0)":
|
|
|
|
## This would be the usual way when no encryption is done or when it is done
|
|
|
|
## on the application layer.
|
|
|
|
|
|
|
|
# Encoding
|
|
|
|
let
|
|
|
|
version = 0'u32
|
|
|
|
payload = @[byte 0, 1, 2]
|
|
|
|
msg = WakuMessage(payload: payload, version: version)
|
|
|
|
pb = msg.encode()
|
|
|
|
|
|
|
|
# Decoding
|
2022-11-07 16:24:16 +01:00
|
|
|
let msgDecoded = WakuMessage.decode(pb.buffer)
|
2020-11-03 21:20:40 +01:00
|
|
|
check msgDecoded.isOk()
|
|
|
|
|
|
|
|
let
|
|
|
|
keyInfo = KeyInfo(kind:None)
|
|
|
|
decoded = decodePayload(msgDecoded.get(), keyInfo)
|
|
|
|
|
|
|
|
check:
|
|
|
|
decoded.isOk()
|
|
|
|
decoded.get().payload == payload
|
|
|
|
|
|
|
|
test "Encode/Decode without encryption (version 0) with encodePayload":
|
|
|
|
## This is a bit silly and only there for completeness
|
|
|
|
|
|
|
|
# Encoding
|
|
|
|
let
|
|
|
|
version = 0'u32
|
|
|
|
payload = Payload(payload: @[byte 0, 1, 2])
|
|
|
|
encodedPayload = payload.encode(version, rng[])
|
|
|
|
|
|
|
|
check encodedPayload.isOk()
|
|
|
|
let
|
|
|
|
msg = WakuMessage(payload: encodedPayload.get(), version: version)
|
|
|
|
pb = msg.encode()
|
|
|
|
|
|
|
|
# Decoding
|
2022-11-07 16:24:16 +01:00
|
|
|
let msgDecoded = WakuMessage.decode(pb.buffer)
|
2020-11-03 21:20:40 +01:00
|
|
|
check msgDecoded.isOk()
|
|
|
|
|
|
|
|
let
|
|
|
|
keyInfo = KeyInfo(kind:None)
|
|
|
|
decoded = decodePayload(msgDecoded.get(), keyInfo)
|
|
|
|
|
|
|
|
check:
|
|
|
|
decoded.isOk()
|
|
|
|
decoded.get().payload == payload.payload
|
|
|
|
|
|
|
|
test "Encode/Decode with encryption (version 1)":
|
|
|
|
# Encoding
|
|
|
|
let
|
|
|
|
privKey = PrivateKey.random(rng[])
|
|
|
|
version = 1'u32
|
|
|
|
payload = Payload(payload: @[byte 0, 1, 2],
|
|
|
|
dst: some(privKey.toPublicKey()))
|
|
|
|
encodedPayload = payload.encode(version, rng[])
|
|
|
|
|
|
|
|
check encodedPayload.isOk()
|
|
|
|
let
|
|
|
|
msg = WakuMessage(payload: encodedPayload.get(), version: version)
|
|
|
|
pb = msg.encode()
|
|
|
|
|
|
|
|
# Decoding
|
2022-11-07 16:24:16 +01:00
|
|
|
let msgDecoded = WakuMessage.decode(pb.buffer)
|
2020-11-03 21:20:40 +01:00
|
|
|
check msgDecoded.isOk()
|
|
|
|
|
|
|
|
let
|
|
|
|
keyInfo = KeyInfo(kind: Asymmetric, privKey: privKey)
|
|
|
|
decoded = decodePayload(msgDecoded.get(), keyInfo)
|
|
|
|
|
|
|
|
check:
|
|
|
|
decoded.isOk()
|
|
|
|
decoded.get().payload == payload.payload
|
|
|
|
|
|
|
|
test "Encode with unsupported version":
|
|
|
|
let
|
|
|
|
version = 2'u32
|
|
|
|
payload = Payload(payload: @[byte 0, 1, 2])
|
|
|
|
encodedPayload = payload.encode(version, rng[])
|
|
|
|
|
|
|
|
check encodedPayload.isErr()
|
|
|
|
|
|
|
|
test "Decode with unsupported version":
|
|
|
|
# Encoding
|
|
|
|
let
|
|
|
|
version = 2'u32
|
|
|
|
payload = @[byte 0, 1, 2]
|
|
|
|
msg = WakuMessage(payload: payload, version: version)
|
|
|
|
pb = msg.encode()
|
|
|
|
|
|
|
|
# Decoding
|
2022-11-07 16:24:16 +01:00
|
|
|
let msgDecoded = WakuMessage.decode(pb.buffer)
|
2020-11-03 21:20:40 +01:00
|
|
|
check msgDecoded.isOk()
|
|
|
|
|
|
|
|
let
|
|
|
|
keyInfo = KeyInfo(kind:None)
|
|
|
|
decoded = decodePayload(msgDecoded.get(), keyInfo)
|
|
|
|
|
|
|
|
check:
|
|
|
|
decoded.isErr()
|
2022-08-01 12:37:45 +02:00
|
|
|
|
|
|
|
test "Encode/Decode waku message with timestamp":
|
|
|
|
## Test encoding and decoding of the timestamp field of a WakuMessage
|
|
|
|
|
|
|
|
## Given
|
|
|
|
let
|
|
|
|
version = 0'u32
|
|
|
|
payload = @[byte 0, 1, 2]
|
|
|
|
timestamp = Timestamp(10)
|
|
|
|
msg = WakuMessage(payload: payload, version: version, timestamp: timestamp)
|
2023-02-07 10:45:25 +01:00
|
|
|
|
2022-08-01 12:37:45 +02:00
|
|
|
## When
|
|
|
|
let pb = msg.encode()
|
2022-11-07 16:24:16 +01:00
|
|
|
let msgDecoded = WakuMessage.decode(pb.buffer)
|
2023-02-07 10:45:25 +01:00
|
|
|
|
2022-08-01 12:37:45 +02:00
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
msgDecoded.isOk()
|
2023-02-07 10:45:25 +01:00
|
|
|
|
2022-08-01 12:37:45 +02:00
|
|
|
let timestampDecoded = msgDecoded.value.timestamp
|
|
|
|
check:
|
|
|
|
timestampDecoded == timestamp
|
|
|
|
|
|
|
|
test "Encode/Decode waku message without timestamp":
|
2023-02-07 10:45:25 +01:00
|
|
|
## Test the encoding and decoding of a WakuMessage with an empty timestamp field
|
2022-08-01 12:37:45 +02:00
|
|
|
|
|
|
|
## Given
|
|
|
|
let
|
|
|
|
version = 0'u32
|
|
|
|
payload = @[byte 0, 1, 2]
|
|
|
|
msg = WakuMessage(payload: payload, version: version)
|
2023-02-07 10:45:25 +01:00
|
|
|
|
2022-08-01 12:37:45 +02:00
|
|
|
## When
|
|
|
|
let pb = msg.encode()
|
2022-11-07 16:24:16 +01:00
|
|
|
let msgDecoded = WakuMessage.decode(pb.buffer)
|
2022-08-01 12:37:45 +02:00
|
|
|
|
|
|
|
## Then
|
|
|
|
check:
|
|
|
|
msgDecoded.isOk()
|
2023-02-07 10:45:25 +01:00
|
|
|
|
2022-08-01 12:37:45 +02:00
|
|
|
let timestampDecoded = msgDecoded.value.timestamp
|
|
|
|
check:
|
2023-02-07 10:45:25 +01:00
|
|
|
timestampDecoded == Timestamp(0)
|