swarm_test.go 3.38 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13
package swarm

import (
	"fmt"
	"testing"

	msg "github.com/jbenet/go-ipfs/net/message"
	peer "github.com/jbenet/go-ipfs/peer"
	u "github.com/jbenet/go-ipfs/util"

	context "github.com/jbenet/go-ipfs/Godeps/_workspace/src/code.google.com/p/go.net/context"
	msgio "github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-msgio"
	ma "github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr"
14
	manet "github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr/net"
15 16 17
	mh "github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multihash"
)

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
18
func pingListen(t *testing.T, listener manet.Listener, peer *peer.Peer) {
19 20 21 22 23 24 25 26
	for {
		c, err := listener.Accept()
		if err == nil {
			go pong(t, c, peer)
		}
	}
}

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
27
func pong(t *testing.T, c manet.Conn, peer *peer.Peer) {
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
	mrw := msgio.NewReadWriter(c)
	for {
		data := make([]byte, 1024)
		n, err := mrw.ReadMsg(data)
		if err != nil {
			fmt.Printf("error %v\n", err)
			return
		}
		d := string(data[:n])
		if d != "ping" {
			t.Errorf("error: didn't receive ping: '%v'\n", d)
			return
		}
		err = mrw.WriteMsg([]byte("pong"))
		if err != nil {
			fmt.Printf("error %v\n", err)
			return
		}
	}
}

func setupPeer(id string, addr string) (*peer.Peer, error) {
	tcp, err := ma.NewMultiaddr(addr)
	if err != nil {
		return nil, err
	}

	mh, err := mh.FromHexString(id)
	if err != nil {
		return nil, err
	}

	p := &peer.Peer{ID: peer.ID(mh)}
	p.AddAddress(tcp)
	return p, nil
}

func TestSwarm(t *testing.T) {
66
	t.Skip("TODO FIXME nil pointer")
67 68 69 70 71 72 73

	local, err := setupPeer("11140beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a30",
		"/ip4/127.0.0.1/tcp/1234")
	if err != nil {
		t.Fatal("error setting up peer", err)
	}

Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
74 75 76
	peerstore := peer.NewPeerstore()

	swarm, err := NewSwarm(context.Background(), local, peerstore)
77 78 79 80
	if err != nil {
		t.Error(err)
	}
	var peers []*peer.Peer
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
81
	var listeners []manet.Listener
82 83 84 85
	peerNames := map[string]string{
		"11140beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a31": "/ip4/127.0.0.1/tcp/2345",
		"11140beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a32": "/ip4/127.0.0.1/tcp/3456",
		"11140beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a33": "/ip4/127.0.0.1/tcp/4567",
86
		"11140beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a34": "/ip4/127.0.0.1/tcp/5678",
87 88 89 90 91 92 93 94 95 96 97
	}

	for k, n := range peerNames {
		peer, err := setupPeer(k, n)
		if err != nil {
			t.Fatal("error setting up peer", err)
		}
		a := peer.NetAddress("tcp")
		if a == nil {
			t.Fatal("error setting up peer (addr is nil)", peer)
		}
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
98
		listener, err := manet.Listen(a)
99 100 101
		if err != nil {
			t.Fatal("error setting up listener", err)
		}
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
102
		go pingListen(t, listener, peer)
103 104 105 106 107 108 109 110 111 112 113 114 115 116

		_, err = swarm.Dial(peer)
		if err != nil {
			t.Fatal("error swarm dialing to peer", err)
		}

		// ok done, add it.
		peers = append(peers, peer)
		listeners = append(listeners, listener)
	}

	MsgNum := 1000
	for k := 0; k < MsgNum; k++ {
		for _, p := range peers {
117
			swarm.Outgoing <- msg.New(p, []byte("ping"))
118 119 120 121 122 123 124
		}
	}

	got := map[u.Key]int{}

	for k := 0; k < (MsgNum * len(peers)); k++ {
		msg := <-swarm.Incoming
125
		if string(msg.Data()) != "pong" {
126 127 128
			t.Error("unexpected conn output", msg.Data)
		}

129 130
		n, _ := got[msg.Peer().Key()]
		got[msg.Peer().Key()] = n + 1
131 132 133 134 135 136 137 138 139 140 141 142 143 144
	}

	if len(peers) != len(got) {
		t.Error("got less messages than sent")
	}

	for p, n := range got {
		if n != MsgNum {
			t.Error("peer did not get all msgs", p, n, "/", MsgNum)
		}
	}

	swarm.Close()
	for _, listener := range listeners {
Juan Batiz-Benet's avatar
Juan Batiz-Benet committed
145
		listener.Close()
146 147
	}
}