swarm_net_test.go 3.89 KB
Newer Older
Steven Allen's avatar
Steven Allen committed
1
package swarm_test
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
2 3

import (
Jeromy's avatar
Jeromy committed
4
	"context"
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
5 6 7 8
	"fmt"
	"testing"
	"time"

9
	"github.com/libp2p/go-libp2p-core/network"
Jeromy's avatar
Jeromy committed
10

Steven Allen's avatar
Steven Allen committed
11 12
	. "github.com/libp2p/go-libp2p-swarm/testing"
)
Jeromy's avatar
Jeromy committed
13

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
14 15 16 17 18 19
// TestConnectednessCorrect starts a few networks, connects a few
// and tests Connectedness value is correct.
func TestConnectednessCorrect(t *testing.T) {

	ctx := context.Background()

20
	nets := make([]network.Network, 4)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
21
	for i := 0; i < 4; i++ {
Steven Allen's avatar
Steven Allen committed
22
		nets[i] = GenSwarm(t, ctx)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
23 24 25 26
	}

	// connect 0-1, 0-2, 0-3, 1-2, 2-3

27
	dial := func(a, b network.Network) {
Jeromy's avatar
Jeromy committed
28
		DivulgeAddresses(b, a)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
29 30 31 32 33 34 35 36 37 38
		if _, err := a.DialPeer(ctx, b.LocalPeer()); err != nil {
			t.Fatalf("Failed to dial: %s", err)
		}
	}

	dial(nets[0], nets[1])
	dial(nets[0], nets[3])
	dial(nets[1], nets[2])
	dial(nets[3], nets[2])

Jeromy's avatar
Jeromy committed
39 40 41 42
	// The notifications for new connections get sent out asynchronously.
	// There is the potential for a race condition here, so we sleep to ensure
	// that they have been received.
	time.Sleep(time.Millisecond * 100)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
43 44 45 46

	// test those connected show up correctly

	// test connected
47 48 49 50
	expectConnectedness(t, nets[0], nets[1], network.Connected)
	expectConnectedness(t, nets[0], nets[3], network.Connected)
	expectConnectedness(t, nets[1], nets[2], network.Connected)
	expectConnectedness(t, nets[3], nets[2], network.Connected)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
51 52

	// test not connected
53 54
	expectConnectedness(t, nets[0], nets[2], network.NotConnected)
	expectConnectedness(t, nets[1], nets[3], network.NotConnected)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
55

Jeromy's avatar
Jeromy committed
56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
	if len(nets[0].Peers()) != 2 {
		t.Fatal("expected net 0 to have two peers")
	}

	if len(nets[2].Conns()) != 2 {
		t.Fatal("expected net 2 to have two conns")
	}

	if len(nets[1].ConnsToPeer(nets[3].LocalPeer())) != 0 {
		t.Fatal("net 1 should have no connections to net 3")
	}

	if err := nets[2].ClosePeer(nets[1].LocalPeer()); err != nil {
		t.Fatal(err)
	}

72 73
	time.Sleep(time.Millisecond * 50)

74
	expectConnectedness(t, nets[2], nets[1], network.NotConnected)
Jeromy's avatar
Jeromy committed
75

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
76 77 78
	for _, n := range nets {
		n.Close()
	}
Jeromy's avatar
Jeromy committed
79 80 81 82

	for _, n := range nets {
		<-n.Process().Closed()
	}
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
83 84
}

85
func expectConnectedness(t *testing.T, a, b network.Network, expected network.Connectedness) {
Jeromy's avatar
Jeromy committed
86 87 88 89 90
	es := "%s is connected to %s, but Connectedness incorrect. %s %s %s"
	atob := a.Connectedness(b.LocalPeer())
	btoa := b.Connectedness(a.LocalPeer())
	if atob != expected {
		t.Errorf(es, a, b, printConns(a), printConns(b), atob)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
91 92 93
	}

	// test symmetric case
Jeromy's avatar
Jeromy committed
94 95
	if btoa != expected {
		t.Errorf(es, b, a, printConns(b), printConns(a), btoa)
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
96 97 98
	}
}

99
func printConns(n network.Network) string {
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
100 101 102 103 104 105
	s := fmt.Sprintf("Connections in %s:\n", n)
	for _, c := range n.Conns() {
		s = s + fmt.Sprintf("- %s\n", c)
	}
	return s
}
Jeromy's avatar
Jeromy committed
106 107 108 109 110

func TestNetworkOpenStream(t *testing.T) {
	ctx, cancel := context.WithCancel(context.Background())
	defer cancel()

111
	nets := make([]network.Network, 4)
Jeromy's avatar
Jeromy committed
112
	for i := 0; i < 4; i++ {
Steven Allen's avatar
Steven Allen committed
113
		nets[i] = GenSwarm(t, ctx)
Jeromy's avatar
Jeromy committed
114 115
	}

116
	dial := func(a, b network.Network) {
Jeromy's avatar
Jeromy committed
117
		DivulgeAddresses(b, a)
Jeromy's avatar
Jeromy committed
118 119 120 121 122 123 124 125 126 127
		if _, err := a.DialPeer(ctx, b.LocalPeer()); err != nil {
			t.Fatalf("Failed to dial: %s", err)
		}
	}

	dial(nets[0], nets[1])
	dial(nets[0], nets[3])
	dial(nets[1], nets[2])

	done := make(chan bool)
128
	nets[1].SetStreamHandler(func(s network.Stream) {
Jeromy's avatar
Jeromy committed
129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147
		defer close(done)
		defer s.Close()

		buf := make([]byte, 10)
		_, err := s.Read(buf)
		if err != nil {
			t.Error(err)
			return
		}
		if string(buf) != "hello ipfs" {
			t.Error("got wrong message")
		}
	})

	s, err := nets[0].NewStream(ctx, nets[1].LocalPeer())
	if err != nil {
		t.Fatal(err)
	}

Steven Allen's avatar
Steven Allen committed
148
	streams := nets[0].ConnsToPeer(nets[1].LocalPeer())[0].GetStreams()
Jeromy's avatar
Jeromy committed
149 150 151 152 153 154 155 156
	if err != nil {
		t.Fatal(err)
	}

	if len(streams) != 1 {
		t.Fatal("should only have one stream there")
	}

Jeromy's avatar
Jeromy committed
157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177
	_, err = s.Write([]byte("hello ipfs"))
	if err != nil {
		t.Fatal(err)
	}

	err = s.Close()
	if err != nil {
		t.Fatal(err)
	}

	select {
	case <-done:
	case <-time.After(time.Millisecond * 100):
		t.Fatal("timed out waiting on stream")
	}

	_, err = nets[1].NewStream(ctx, nets[3].LocalPeer())
	if err == nil {
		t.Fatal("expected stream open 1->3 to fail")
	}
}