server_test.go 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. package p2p
  2. import (
  3. "bytes"
  4. "fmt"
  5. "net"
  6. "testing"
  7. "time"
  8. )
  9. type TestNetwork struct {
  10. connections map[string]*TestNetworkConnection
  11. dialer Dialer
  12. maxinbound int
  13. }
  14. func NewTestNetwork(maxinbound int) *TestNetwork {
  15. connections := make(map[string]*TestNetworkConnection)
  16. return &TestNetwork{
  17. connections: connections,
  18. dialer: &TestDialer{connections},
  19. maxinbound: maxinbound,
  20. }
  21. }
  22. func (self *TestNetwork) Dialer(addr net.Addr) (Dialer, error) {
  23. return self.dialer, nil
  24. }
  25. func (self *TestNetwork) Listener(addr net.Addr) (net.Listener, error) {
  26. return &TestListener{
  27. connections: self.connections,
  28. addr: addr,
  29. max: self.maxinbound,
  30. }, nil
  31. }
  32. func (self *TestNetwork) Start() error {
  33. return nil
  34. }
  35. func (self *TestNetwork) NewAddr(string, int) (addr net.Addr, err error) {
  36. return
  37. }
  38. func (self *TestNetwork) ParseAddr(string) (addr net.Addr, err error) {
  39. return
  40. }
  41. type TestAddr struct {
  42. name string
  43. }
  44. func (self *TestAddr) String() string {
  45. return self.name
  46. }
  47. func (*TestAddr) Network() string {
  48. return "test"
  49. }
  50. type TestDialer struct {
  51. connections map[string]*TestNetworkConnection
  52. }
  53. func (self *TestDialer) Dial(network string, addr string) (conn net.Conn, err error) {
  54. address := &TestAddr{addr}
  55. tconn := NewTestNetworkConnection(address)
  56. self.connections[addr] = tconn
  57. conn = net.Conn(tconn)
  58. return
  59. }
  60. type TestListener struct {
  61. connections map[string]*TestNetworkConnection
  62. addr net.Addr
  63. max int
  64. i int
  65. }
  66. func (self *TestListener) Accept() (conn net.Conn, err error) {
  67. self.i++
  68. if self.i > self.max {
  69. err = fmt.Errorf("no more")
  70. } else {
  71. addr := &TestAddr{fmt.Sprintf("inboundpeer-%d", self.i)}
  72. tconn := NewTestNetworkConnection(addr)
  73. key := tconn.RemoteAddr().String()
  74. self.connections[key] = tconn
  75. conn = net.Conn(tconn)
  76. fmt.Printf("accepted connection from: %v \n", addr)
  77. }
  78. return
  79. }
  80. func (self *TestListener) Close() error {
  81. return nil
  82. }
  83. func (self *TestListener) Addr() net.Addr {
  84. return self.addr
  85. }
  86. func SetupTestServer(handlers Handlers) (network *TestNetwork, server *Server) {
  87. network = NewTestNetwork(1)
  88. addr := &TestAddr{"test:30303"}
  89. identity := NewSimpleClientIdentity("clientIdentifier", "version", "customIdentifier", "pubkey")
  90. maxPeers := 2
  91. if handlers == nil {
  92. handlers = make(Handlers)
  93. }
  94. blackist := NewBlacklist()
  95. server = New(network, addr, identity, handlers, maxPeers, blackist)
  96. fmt.Println(server.identity.Pubkey())
  97. return
  98. }
  99. func TestServerListener(t *testing.T) {
  100. network, server := SetupTestServer(nil)
  101. server.Start(true, false)
  102. time.Sleep(10 * time.Millisecond)
  103. server.Stop()
  104. peer1, ok := network.connections["inboundpeer-1"]
  105. if !ok {
  106. t.Error("not found inbound peer 1")
  107. } else {
  108. fmt.Printf("out: %v\n", peer1.Out)
  109. if len(peer1.Out) != 2 {
  110. t.Errorf("not enough messages sent to peer 1: %v ", len(peer1.Out))
  111. }
  112. }
  113. }
  114. func TestServerDialer(t *testing.T) {
  115. network, server := SetupTestServer(nil)
  116. server.Start(false, true)
  117. server.peerConnect <- &TestAddr{"outboundpeer-1"}
  118. time.Sleep(10 * time.Millisecond)
  119. server.Stop()
  120. peer1, ok := network.connections["outboundpeer-1"]
  121. if !ok {
  122. t.Error("not found outbound peer 1")
  123. } else {
  124. fmt.Printf("out: %v\n", peer1.Out)
  125. if len(peer1.Out) != 2 {
  126. t.Errorf("not enough messages sent to peer 1: %v ", len(peer1.Out))
  127. }
  128. }
  129. }
  130. func TestServerBroadcast(t *testing.T) {
  131. handlers := make(Handlers)
  132. testProtocol := &TestProtocol{Msgs: []*Msg{}}
  133. handlers["aaa"] = func(p *Peer) Protocol { return testProtocol }
  134. network, server := SetupTestServer(handlers)
  135. server.Start(true, true)
  136. server.peerConnect <- &TestAddr{"outboundpeer-1"}
  137. time.Sleep(10 * time.Millisecond)
  138. msg, _ := NewMsg(0)
  139. server.Broadcast("", msg)
  140. packet := Packet(0, 0)
  141. time.Sleep(10 * time.Millisecond)
  142. server.Stop()
  143. peer1, ok := network.connections["outboundpeer-1"]
  144. if !ok {
  145. t.Error("not found outbound peer 1")
  146. } else {
  147. fmt.Printf("out: %v\n", peer1.Out)
  148. if len(peer1.Out) != 3 {
  149. t.Errorf("not enough messages sent to peer 1: %v ", len(peer1.Out))
  150. } else {
  151. if bytes.Compare(peer1.Out[1], packet) != 0 {
  152. t.Errorf("incorrect broadcast packet %v != %v", peer1.Out[1], packet)
  153. }
  154. }
  155. }
  156. peer2, ok := network.connections["inboundpeer-1"]
  157. if !ok {
  158. t.Error("not found inbound peer 2")
  159. } else {
  160. fmt.Printf("out: %v\n", peer2.Out)
  161. if len(peer1.Out) != 3 {
  162. t.Errorf("not enough messages sent to peer 2: %v ", len(peer2.Out))
  163. } else {
  164. if bytes.Compare(peer2.Out[1], packet) != 0 {
  165. t.Errorf("incorrect broadcast packet %v != %v", peer2.Out[1], packet)
  166. }
  167. }
  168. }
  169. }
  170. func TestServerPeersMessage(t *testing.T) {
  171. handlers := make(Handlers)
  172. _, server := SetupTestServer(handlers)
  173. server.Start(true, true)
  174. defer server.Stop()
  175. server.peerConnect <- &TestAddr{"outboundpeer-1"}
  176. time.Sleep(10 * time.Millisecond)
  177. peersMsg, err := server.PeersMessage()
  178. fmt.Println(peersMsg)
  179. if err != nil {
  180. t.Errorf("expect no error, got %v", err)
  181. }
  182. if c := server.PeerCount(); c != 2 {
  183. t.Errorf("expect 2 peers, got %v", c)
  184. }
  185. }