2020-05-06 18:31:47 +02:00
|
|
|
{.used.}
|
2019-12-07 10:36:39 -06:00
|
|
|
|
2023-05-18 10:24:17 +02:00
|
|
|
# Nim-Libp2p
|
|
|
|
# Copyright (c) 2023 Status Research & Development GmbH
|
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
|
|
|
|
# at your option.
|
|
|
|
# This file may not be copied, modified, or distributed except according to
|
|
|
|
# those terms.
|
|
|
|
|
2022-06-16 10:08:52 +02:00
|
|
|
import options
|
2023-05-18 10:24:17 +02:00
|
|
|
import chronos
|
2019-12-07 10:36:39 -06:00
|
|
|
import ../libp2p/crypto/crypto,
|
2022-03-14 09:39:30 +01:00
|
|
|
../libp2p/multicodec,
|
2019-12-07 10:36:39 -06:00
|
|
|
../libp2p/peerinfo,
|
2022-03-14 09:39:30 +01:00
|
|
|
../libp2p/peerid,
|
|
|
|
../libp2p/routing_record
|
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()
|
2021-10-25 10:26:32 +02:00
|
|
|
var peerInfo = PeerInfo.new(seckey)
|
2021-12-16 11:05:20 +01:00
|
|
|
var peerId = PeerId.init(seckey).get()
|
2019-12-07 10:36:39 -06:00
|
|
|
|
|
|
|
check peerId == peerInfo.peerId
|
2021-09-08 11:07:46 +02:00
|
|
|
check seckey.getPublicKey().get() == peerInfo.publicKey
|
2022-10-20 12:22:28 +02:00
|
|
|
|
2022-03-14 09:39:30 +01:00
|
|
|
test "Signed peer record":
|
|
|
|
const
|
|
|
|
ExpectedDomain = $multiCodec("libp2p-peer-record")
|
|
|
|
ExpectedPayloadType = @[(byte) 0x03, (byte) 0x01]
|
2022-10-20 12:22:28 +02:00
|
|
|
|
2022-03-14 09:39:30 +01:00
|
|
|
let
|
|
|
|
seckey = PrivateKey.random(rng[]).tryGet()
|
2022-07-27 11:47:50 +00:00
|
|
|
peerId = PeerId.init(seckey).get()
|
2022-03-14 09:39:30 +01:00
|
|
|
multiAddresses = @[MultiAddress.init("/ip4/0.0.0.0/tcp/24").tryGet(), MultiAddress.init("/ip4/0.0.0.0/tcp/25").tryGet()]
|
|
|
|
peerInfo = PeerInfo.new(seckey, multiAddresses)
|
2022-10-20 12:22:28 +02:00
|
|
|
|
|
|
|
waitFor(peerInfo.update())
|
|
|
|
|
2022-03-14 09:39:30 +01:00
|
|
|
let
|
2022-04-13 09:35:28 +02:00
|
|
|
env = peerInfo.signedPeerRecord.envelope
|
2022-03-14 09:39:30 +01:00
|
|
|
rec = PeerRecord.decode(env.payload()).tryGet()
|
2022-10-20 12:22:28 +02:00
|
|
|
|
2022-03-14 09:39:30 +01:00
|
|
|
# Check envelope fields
|
|
|
|
check:
|
|
|
|
env.publicKey == peerInfo.publicKey
|
|
|
|
env.domain == ExpectedDomain
|
|
|
|
env.payloadType == ExpectedPayloadType
|
|
|
|
|
|
|
|
# Check payload (routing record)
|
|
|
|
check:
|
|
|
|
rec.peerId == peerId
|
|
|
|
rec.seqNo > 0
|
|
|
|
rec.addresses.len == 2
|
|
|
|
rec.addresses[0].address == multiAddresses[0]
|
|
|
|
rec.addresses[1].address == multiAddresses[1]
|
2022-10-20 12:22:28 +02:00
|
|
|
|
|
|
|
test "Public address mapping":
|
|
|
|
let
|
|
|
|
seckey = PrivateKey.random(ECDSA, rng[]).get()
|
|
|
|
multiAddresses = @[MultiAddress.init("/ip4/0.0.0.0/tcp/24").tryGet(), MultiAddress.init("/ip4/0.0.0.0/tcp/25").tryGet()]
|
|
|
|
multiAddresses2 = @[MultiAddress.init("/ip4/8.8.8.8/tcp/33").tryGet()]
|
|
|
|
|
|
|
|
proc addressMapper(input: seq[MultiAddress]): Future[seq[MultiAddress]] {.async.} =
|
|
|
|
check input == multiAddresses
|
|
|
|
await sleepAsync(0.seconds)
|
|
|
|
return multiAddresses2
|
|
|
|
var peerInfo = PeerInfo.new(seckey, multiAddresses, addressMappers = @[addressMapper])
|
|
|
|
waitFor peerInfo.update()
|
|
|
|
check peerInfo.addrs == multiAddresses2
|