mirror of
https://source.quilibrium.com/quilibrium/ceremonyclient.git
synced 2025-01-20 12:45:17 +00:00
153 lines
3.7 KiB
Go
153 lines
3.7 KiB
Go
|
package peer_test
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
ma "github.com/multiformats/go-multiaddr"
|
||
|
|
||
|
. "github.com/libp2p/go-libp2p/core/peer"
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
testID ID
|
||
|
maddrFull, maddrTpt, maddrPeer ma.Multiaddr
|
||
|
)
|
||
|
|
||
|
func init() {
|
||
|
var err error
|
||
|
testID, err = Decode("QmS3zcG7LhYZYSJMhyRZvTddvbNUqtt8BJpaSs6mi1K5Va")
|
||
|
if err != nil {
|
||
|
panic(err)
|
||
|
}
|
||
|
maddrPeer = ma.StringCast("/p2p/" + Encode(testID))
|
||
|
maddrTpt = ma.StringCast("/ip4/127.0.0.1/tcp/1234")
|
||
|
maddrFull = maddrTpt.Encapsulate(maddrPeer)
|
||
|
}
|
||
|
|
||
|
func TestSplitAddr(t *testing.T) {
|
||
|
tpt, id := SplitAddr(maddrFull)
|
||
|
if !tpt.Equal(maddrTpt) {
|
||
|
t.Fatal("expected transport")
|
||
|
}
|
||
|
if id != testID {
|
||
|
t.Fatalf("%s != %s", id, testID)
|
||
|
}
|
||
|
|
||
|
tpt, id = SplitAddr(maddrPeer)
|
||
|
if tpt != nil {
|
||
|
t.Fatal("expected no transport")
|
||
|
}
|
||
|
if id != testID {
|
||
|
t.Fatalf("%s != %s", id, testID)
|
||
|
}
|
||
|
|
||
|
tpt, id = SplitAddr(maddrTpt)
|
||
|
if !tpt.Equal(maddrTpt) {
|
||
|
t.Fatal("expected a transport")
|
||
|
}
|
||
|
if id != "" {
|
||
|
t.Fatal("expected no peer ID")
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestAddrInfoFromP2pAddr(t *testing.T) {
|
||
|
ai, err := AddrInfoFromP2pAddr(maddrFull)
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
if len(ai.Addrs) != 1 || !ai.Addrs[0].Equal(maddrTpt) {
|
||
|
t.Fatal("expected transport")
|
||
|
}
|
||
|
if ai.ID != testID {
|
||
|
t.Fatalf("%s != %s", ai.ID, testID)
|
||
|
}
|
||
|
|
||
|
ai, err = AddrInfoFromP2pAddr(maddrPeer)
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
if len(ai.Addrs) != 0 {
|
||
|
t.Fatal("expected transport")
|
||
|
}
|
||
|
if ai.ID != testID {
|
||
|
t.Fatalf("%s != %s", ai.ID, testID)
|
||
|
}
|
||
|
|
||
|
_, err = AddrInfoFromP2pAddr(maddrTpt)
|
||
|
if err != ErrInvalidAddr {
|
||
|
t.Fatalf("wrong error: %s", err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestAddrInfosFromP2pAddrs(t *testing.T) {
|
||
|
infos, err := AddrInfosFromP2pAddrs()
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
if len(infos) != 0 {
|
||
|
t.Fatal("expected no addrs")
|
||
|
}
|
||
|
if _, err = AddrInfosFromP2pAddrs(nil); err == nil {
|
||
|
t.Fatal("expected nil multiaddr to fail")
|
||
|
}
|
||
|
|
||
|
addrs := []ma.Multiaddr{
|
||
|
ma.StringCast("/ip4/128.199.219.111/tcp/4001/ipfs/QmSoLV4Bbm51jM9C4gDYZQ9Cy3U6aXMJDAbzgu2fzaDs64"),
|
||
|
ma.StringCast("/ip4/104.236.76.40/tcp/4001/ipfs/QmSoLV4Bbm51jM9C4gDYZQ9Cy3U6aXMJDAbzgu2fzaDs64"),
|
||
|
|
||
|
ma.StringCast("/ipfs/QmSoLer265NRgSp2LA3dPaeykiS1J6DifTC88f5uVQKNAd"),
|
||
|
ma.StringCast("/ip4/178.62.158.247/tcp/4001/ipfs/QmSoLer265NRgSp2LA3dPaeykiS1J6DifTC88f5uVQKNAd"),
|
||
|
|
||
|
ma.StringCast("/ipfs/QmSoLPppuBtQSGwKDZT2M73ULpjvfd3aZ6ha4oFGL1KrGM"),
|
||
|
}
|
||
|
expected := map[string][]ma.Multiaddr{
|
||
|
"QmSoLV4Bbm51jM9C4gDYZQ9Cy3U6aXMJDAbzgu2fzaDs64": {
|
||
|
ma.StringCast("/ip4/128.199.219.111/tcp/4001"),
|
||
|
ma.StringCast("/ip4/104.236.76.40/tcp/4001"),
|
||
|
},
|
||
|
"QmSoLer265NRgSp2LA3dPaeykiS1J6DifTC88f5uVQKNAd": {
|
||
|
ma.StringCast("/ip4/178.62.158.247/tcp/4001"),
|
||
|
},
|
||
|
"QmSoLPppuBtQSGwKDZT2M73ULpjvfd3aZ6ha4oFGL1KrGM": nil,
|
||
|
}
|
||
|
infos, err = AddrInfosFromP2pAddrs(addrs...)
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
for _, info := range infos {
|
||
|
exaddrs, ok := expected[info.ID.Pretty()]
|
||
|
if !ok {
|
||
|
t.Fatalf("didn't expect peer %s", info.ID)
|
||
|
}
|
||
|
if len(info.Addrs) != len(exaddrs) {
|
||
|
t.Fatalf("got %d addrs, expected %d", len(info.Addrs), len(exaddrs))
|
||
|
}
|
||
|
// AddrInfosFromP2pAddrs preserves order. I'd like to keep this
|
||
|
// guarantee for now.
|
||
|
for i, addr := range info.Addrs {
|
||
|
if !exaddrs[i].Equal(addr) {
|
||
|
t.Fatalf("expected %s, got %s", exaddrs[i], addr)
|
||
|
}
|
||
|
}
|
||
|
delete(expected, info.ID.Pretty())
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestAddrInfoJSON(t *testing.T) {
|
||
|
ai := AddrInfo{ID: testID, Addrs: []ma.Multiaddr{maddrFull}}
|
||
|
out, err := ai.MarshalJSON()
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
var addrInfo AddrInfo
|
||
|
if err := addrInfo.UnmarshalJSON(out); err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
if addrInfo.ID != testID {
|
||
|
t.Fatalf("expected ID to equal %s, got %s", testID.Pretty(), addrInfo.ID.Pretty())
|
||
|
}
|
||
|
if len(addrInfo.Addrs) != 1 || !addrInfo.Addrs[0].Equal(maddrFull) {
|
||
|
t.Fatalf("expected addrs to match %v, got %v", maddrFull, addrInfo.Addrs)
|
||
|
}
|
||
|
}
|