2020-05-06 18:31:47 +02:00
|
|
|
{.used.}
|
2019-12-07 10:36:39 -06:00
|
|
|
|
2021-05-21 10:27:01 -06:00
|
|
|
import options, bearssl
|
2020-02-11 19:53:39 +02:00
|
|
|
import chronos
|
2019-12-07 10:36:39 -06:00
|
|
|
import ../libp2p/crypto/crypto,
|
|
|
|
../libp2p/peerinfo,
|
2020-07-01 15:25:09 +09:00
|
|
|
../libp2p/peerid
|
2020-04-21 10:24:42 +09:00
|
|
|
|
2020-07-07 13:14:11 +02:00
|
|
|
import ./helpers
|
|
|
|
|
2019-12-07 10:36:39 -06:00
|
|
|
suite "PeerInfo":
|
|
|
|
test "Should init with private key":
|
2020-07-07 13:14:11 +02:00
|
|
|
let seckey = PrivateKey.random(ECDSA, rng[]).get()
|
2019-12-07 10:36:39 -06:00
|
|
|
var peerInfo = PeerInfo.init(seckey)
|
2020-07-01 15:25:09 +09:00
|
|
|
var peerId = PeerID.init(seckey).get()
|
2019-12-07 10:36:39 -06:00
|
|
|
|
|
|
|
check peerId == peerInfo.peerId
|
|
|
|
check seckey == peerInfo.privateKey
|
2020-05-18 14:25:55 +09:00
|
|
|
check seckey.getKey().get() == peerInfo.publicKey.get()
|
2019-12-07 10:36:39 -06:00
|
|
|
|
|
|
|
test "Should init with public key":
|
2020-07-07 13:14:11 +02:00
|
|
|
let seckey = PrivateKey.random(ECDSA, rng[]).get()
|
2020-05-18 14:25:55 +09:00
|
|
|
var peerInfo = PeerInfo.init(seckey.getKey().get())
|
2020-07-01 15:25:09 +09:00
|
|
|
var peerId = PeerID.init(seckey.getKey().get()).get()
|
2019-12-07 10:36:39 -06:00
|
|
|
|
|
|
|
check peerId == peerInfo.peerId
|
2020-05-18 14:25:55 +09:00
|
|
|
check seckey.getKey.get() == peerInfo.publicKey.get()
|
2019-12-07 10:36:39 -06:00
|
|
|
|
|
|
|
test "Should init from PeerId with public key":
|
2020-07-07 13:14:11 +02:00
|
|
|
let seckey = PrivateKey.random(Ed25519, rng[]).get()
|
2020-07-01 15:25:09 +09:00
|
|
|
var peerInfo = PeerInfo.init(PeerID.init(seckey.getKey.get()).get())
|
|
|
|
var peerId = PeerID.init(seckey.getKey.get()).get()
|
2019-12-07 10:36:39 -06:00
|
|
|
|
|
|
|
check peerId == peerInfo.peerId
|
2020-05-18 14:25:55 +09:00
|
|
|
check seckey.getKey.get() == peerInfo.publicKey.get()
|
2019-12-07 10:36:39 -06:00
|
|
|
|
2019-12-10 14:50:35 -06:00
|
|
|
test "Should init from CIDv0 string":
|
2021-05-21 10:27:01 -06:00
|
|
|
var peerInfo: PeerInfo
|
|
|
|
try:
|
|
|
|
peerInfo = PeerInfo.init("QmYyQSo1c1Ym7orWxLYvCrM2EmxFTANf8wXmmE7DWjhx5N")
|
|
|
|
except CatchableError:
|
|
|
|
check false
|
2019-12-07 10:36:39 -06:00
|
|
|
|
2019-12-10 14:50:35 -06:00
|
|
|
check:
|
2020-07-01 15:25:09 +09:00
|
|
|
PeerID.init("QmYyQSo1c1Ym7orWxLYvCrM2EmxFTANf8wXmmE7DWjhx5N").get() == peerInfo.peerId
|
2019-12-07 10:36:39 -06:00
|
|
|
|
2020-05-23 11:14:22 -06:00
|
|
|
# TODO: CIDv1 handling is missing from PeerID
|
2019-12-10 14:50:35 -06:00
|
|
|
# https://github.com/status-im/nim-libp2p/issues/53
|
|
|
|
# test "Should init from CIDv1 string":
|
|
|
|
# var peerInfo = PeerInfo.init("bafzbeie5745rpv2m6tjyuugywy4d5ewrqgqqhfnf445he3omzpjbx5xqxe")
|
2019-12-07 10:36:39 -06:00
|
|
|
|
2019-12-10 14:50:35 -06:00
|
|
|
# check:
|
|
|
|
# PeerID.init("bafzbeie5745rpv2m6tjyuugywy4d5ewrqgqqhfnf445he3omzpjbx5xqxe") == peerInfo.peerId
|
2019-12-07 10:36:39 -06:00
|
|
|
|
2019-12-10 14:50:35 -06:00
|
|
|
test "Should return none if pubkey is missing from id":
|
2020-07-07 13:14:11 +02:00
|
|
|
let peerInfo = PeerInfo.init(PeerID.init(PrivateKey.random(ECDSA, rng[]).get()).get())
|
2019-12-10 14:50:35 -06:00
|
|
|
check peerInfo.publicKey.isNone
|
2019-12-07 10:36:39 -06:00
|
|
|
|
2019-12-10 14:50:35 -06:00
|
|
|
test "Should return some if pubkey is present in id":
|
2020-07-07 13:14:11 +02:00
|
|
|
let peerInfo = PeerInfo.init(PeerID.init(PrivateKey.random(Ed25519, rng[]).get()).get())
|
2019-12-10 14:50:35 -06:00
|
|
|
check peerInfo.publicKey.isSome
|