// This test is based on go-libp2p/p2p/net/swarm.TestConnectednessCorrect // It builds 4 nodes and connects them, one being the sole center. // Then it checks that the center reports the correct number of peers. func TestPeersTotal(t *testing.T) { ctx := context.Background() hosts := make([]*bhost.BasicHost, 4) for i := 0; i < 4; i++ { hosts[i] = bhost.New(testutil.GenSwarmNetwork(t, ctx)) } dial := func(a, b inet.Network) { testutil.DivulgeAddresses(b, a) if _, err := a.DialPeer(ctx, b.LocalPeer()); err != nil { t.Fatalf("Failed to dial: %s", err) } } dial(hosts[0].Network(), hosts[1].Network()) dial(hosts[0].Network(), hosts[2].Network()) dial(hosts[0].Network(), hosts[3].Network()) // there's something wrong with dial, i think. it's not finishing // completely. there must be some async stuff. <-time.After(100 * time.Millisecond) node := &core.IpfsNode{PeerHost: hosts[0]} collector := IpfsNodeCollector{Node: node} actual := collector.PeersTotalValues() if len(actual) != 1 { t.Fatalf("expected 1 peers transport, got %d", len(actual)) } if actual["/ip4/tcp"] != float64(3) { t.Fatalf("expected 3 peers, got %s", actual["/ip4/tcp"]) } }
// isolates the complex initialization steps func constructPeerHost(ctx context.Context, id peer.ID, ps pstore.Peerstore, bwr metrics.Reporter, fs []*net.IPNet) (p2phost.Host, error) { // no addresses to begin with. we'll start later. network, err := swarm.NewNetwork(ctx, nil, id, ps, bwr) if err != nil { return nil, err } for _, f := range fs { network.Swarm().Filters.AddDialFilter(f) } host := p2pbhost.New(network, p2pbhost.NATPortMap, bwr) return host, nil }