mirror of
https://github.com/status-im/nim-libp2p.git
synced 2025-01-27 21:25:32 +00:00
87 lines
2.8 KiB
Nim
87 lines
2.8 KiB
Nim
import unittest2
|
|
|
|
{.used.}
|
|
|
|
import options
|
|
import stew/byteutils
|
|
import ../../libp2p/[peerid, peerinfo,
|
|
crypto/crypto,
|
|
protocols/pubsub/errors,
|
|
protocols/pubsub/rpc/message,
|
|
protocols/pubsub/rpc/messages]
|
|
|
|
let rng = newRng()
|
|
|
|
suite "Message":
|
|
test "signature":
|
|
var seqno = 11'u64
|
|
let
|
|
peer = PeerInfo.new(PrivateKey.random(ECDSA, rng[]).get())
|
|
msg = Message.init(some(peer), @[], "topic", some(seqno), sign = true)
|
|
|
|
check verify(msg)
|
|
|
|
test "defaultMsgIdProvider success":
|
|
let
|
|
seqno = 11'u64
|
|
pkHex =
|
|
"""08011240B9EA7F0357B5C1247E4FCB5AD09C46818ECB07318CA84711875F4C6C
|
|
E6B946186A4EB44E0D714B2A2D48263D75CF52D30BEF9D9AE2A9FEB7DAF1775F
|
|
E731065A"""
|
|
seckey = PrivateKey.init(fromHex(stripSpaces(pkHex)))
|
|
.expect("valid private key bytes")
|
|
peer = PeerInfo.new(seckey)
|
|
msg = Message.init(some(peer), @[], "topic", some(seqno), sign = true)
|
|
msgIdResult = msg.defaultMsgIdProvider()
|
|
|
|
check:
|
|
msgIdResult.isOk
|
|
string.fromBytes(msgIdResult.get) ==
|
|
"000000000000000b12D3KooWGyLzSt9g4U9TdHYDvVWAs5Ht4WrocgoyqPxxvnqAL8qw"
|
|
|
|
test "defaultMsgIdProvider error - no source peer id":
|
|
let
|
|
seqno = 11'u64
|
|
pkHex =
|
|
"""08011240B9EA7F0357B5C1247E4FCB5AD09C46818ECB07318CA84711875F4C6C
|
|
E6B946186A4EB44E0D714B2A2D48263D75CF52D30BEF9D9AE2A9FEB7DAF1775F
|
|
E731065A"""
|
|
seckey = PrivateKey.init(fromHex(stripSpaces(pkHex)))
|
|
.expect("valid private key bytes")
|
|
peer = PeerInfo.new(seckey)
|
|
|
|
var msg = Message.init(peer.some, @[], "topic", some(seqno), sign = true)
|
|
msg.fromPeer = PeerId()
|
|
let msgIdResult = msg.defaultMsgIdProvider()
|
|
|
|
check:
|
|
msgIdResult.isErr
|
|
msgIdResult.error == ValidationResult.Reject
|
|
|
|
test "defaultMsgIdProvider error - no source seqno":
|
|
let
|
|
pkHex =
|
|
"""08011240B9EA7F0357B5C1247E4FCB5AD09C46818ECB07318CA84711875F4C6C
|
|
E6B946186A4EB44E0D714B2A2D48263D75CF52D30BEF9D9AE2A9FEB7DAF1775F
|
|
E731065A"""
|
|
seckey = PrivateKey.init(fromHex(stripSpaces(pkHex)))
|
|
.expect("valid private key bytes")
|
|
peer = PeerInfo.new(seckey)
|
|
msg = Message.init(some(peer), @[], "topic", uint64.none, sign = true)
|
|
msgIdResult = msg.defaultMsgIdProvider()
|
|
|
|
check:
|
|
msgIdResult.isErr
|
|
msgIdResult.error == ValidationResult.Reject
|
|
|
|
test "byteSize for Message":
|
|
var msg = Message(
|
|
fromPeer: PeerId(data: @[]), # Empty seq[byte]
|
|
data: @[1'u8, 2, 3], # 3 bytes
|
|
seqno: @[1'u8], # 1 byte
|
|
signature: @[], # Empty seq[byte]
|
|
key: @[1'u8], # 1 byte
|
|
topicIds: @["abc", "defgh"] # 3 + 5 = 8 bytes
|
|
)
|
|
|
|
check byteSize(msg) == 3 + 1 + 1 + 8 # Total: 13 bytes |