interface.go 2.96 KB
Newer Older
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
1 2 3 4 5 6 7 8 9
// Package mocknet provides a mock net.Network to test with.
//
// - a Mocknet has many inet.Networks
// - a Mocknet has many Links
// - a Link joins two inet.Networks
// - inet.Conns and inet.Streams are created by inet.Networks
package mocknet

import (
10
	"io"
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
11 12
	"time"

13
	ic "github.com/jbenet/go-ipfs/crypto"
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
14 15
	inet "github.com/jbenet/go-ipfs/net"
	peer "github.com/jbenet/go-ipfs/peer"
16 17

	ma "github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-multiaddr"
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
18 19 20
)

type Mocknet interface {
21 22

	// GenPeer generates a peer and its inet.Network in the Mocknet
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
23
	GenPeer() (inet.Network, error)
24 25 26 27

	// AddPeer adds an existing peer. we need both a privkey and addr.
	// ID is derived from PrivKey
	AddPeer(ic.PrivKey, ma.Multiaddr) (inet.Network, error)
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
28

29
	// retrieve things (with randomized iteration order)
30
	Peers() []peer.ID
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
31 32
	Net(peer.ID) inet.Network
	Nets() []inet.Network
33
	Links() LinkMap
34
	LinksBetweenPeers(a, b peer.ID) []Link
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
35 36 37 38 39 40 41
	LinksBetweenNets(a, b inet.Network) []Link

	// Links are the **ability to connect**.
	// think of Links as the physical medium.
	// For p1 and p2 to connect, a link must exist between them.
	// (this makes it possible to test dial failures, and
	// things like relaying traffic)
42
	LinkPeers(peer.ID, peer.ID) (Link, error)
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
43 44
	LinkNets(inet.Network, inet.Network) (Link, error)
	Unlink(Link) error
45
	UnlinkPeers(peer.ID, peer.ID) error
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
46 47 48 49 50 51 52 53
	UnlinkNets(inet.Network, inet.Network) error

	// LinkDefaults are the default options that govern links
	// if they do not have thier own option set.
	SetLinkDefaults(LinkOptions)
	LinkDefaults() LinkOptions

	// Connections are the usual. Connecting means Dialing.
54
	// **to succeed, peers must be linked beforehand**
55
	ConnectPeers(peer.ID, peer.ID) error
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
56
	ConnectNets(inet.Network, inet.Network) error
57
	DisconnectPeers(peer.ID, peer.ID) error
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
58 59 60
	DisconnectNets(inet.Network, inet.Network) error
}

61 62
// LinkOptions are used to change aspects of the links.
// Sorry but they dont work yet :(
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
63 64 65 66 67 68
type LinkOptions struct {
	Latency   time.Duration
	Bandwidth int // in bytes-per-second
	// we can make these values distributions down the road.
}

69 70 71 72 73
// Link represents the **possibility** of a connection between
// two peers. Think of it like physical network links. Without
// them, the peers can try and try but they won't be able to
// connect. This allows constructing topologies where specific
// nodes cannot talk to each other directly. :)
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
74 75
type Link interface {
	Networks() []inet.Network
76
	Peers() []peer.ID
Juan Batiz-Benet's avatar
mock2  
Juan Batiz-Benet committed
77 78 79 80 81 82

	SetOptions(LinkOptions)
	Options() LinkOptions

	// Metrics() Metrics
}
83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98

// LinkMap is a 3D map to give us an easy way to track links.
// (wow, much map. so data structure. how compose. ahhh pointer)
type LinkMap map[string]map[string]map[Link]struct{}

// Printer lets you inspect things :)
type Printer interface {
	// MocknetLinks shows the entire Mocknet's link table :)
	MocknetLinks(mn Mocknet)
	NetworkConns(ni inet.Network)
}

// PrinterTo returns a Printer ready to write to w.
func PrinterTo(w io.Writer) Printer {
	return &printer{w}
}