package swarm_test import ( "context" "testing" "github.com/libp2p/go-libp2p-core/network" "github.com/libp2p/go-libp2p-core/peer" "github.com/libp2p/go-libp2p-core/peerstore" ma "github.com/multiformats/go-multiaddr" . "github.com/libp2p/go-libp2p-swarm" ) func TestPeers(t *testing.T) { ctx := context.Background() swarms := makeSwarms(ctx, t, 2) s1 := swarms[0] s2 := swarms[1] connect := func(s *Swarm, dst peer.ID, addr ma.Multiaddr) { // TODO: make a DialAddr func. s.Peerstore().AddAddr(dst, addr, peerstore.PermanentAddrTTL) // t.Logf("connections from %s", s.LocalPeer()) // for _, c := range s.ConnsToPeer(dst) { // t.Logf("connection from %s to %s: %v", s.LocalPeer(), dst, c) // } // t.Logf("") if _, err := s.DialPeer(ctx, dst); err != nil { t.Fatal("error swarm dialing to peer", err) } // t.Log(s.swarm.Dump()) } s1GotConn := make(chan struct{}) s2GotConn := make(chan struct{}) s1.SetConnHandler(func(c network.Conn) { s1GotConn <- struct{}{} }) s2.SetConnHandler(func(c network.Conn) { s2GotConn <- struct{}{} }) connect(s1, s2.LocalPeer(), s2.ListenAddresses()[0]) <-s2GotConn // have to wait here so the other side catches up. connect(s2, s1.LocalPeer(), s1.ListenAddresses()[0]) for i := 0; i < 100; i++ { connect(s1, s2.LocalPeer(), s2.ListenAddresses()[0]) connect(s2, s1.LocalPeer(), s1.ListenAddresses()[0]) } for _, s := range swarms { log.Infof("%s swarm routing table: %s", s.LocalPeer(), s.Peers()) } test := func(s *Swarm) { expect := 1 actual := len(s.Peers()) if actual != expect { t.Errorf("%s has %d peers, not %d: %v", s.LocalPeer(), actual, expect, s.Peers()) } actual = len(s.Conns()) if actual != expect { t.Errorf("%s has %d conns, not %d: %v", s.LocalPeer(), actual, expect, s.Conns()) } } test(s1) test(s2) }