github.com/yinchengtsinghua/golang-Eos-dpos-Ethereum@v0.0.0-20190121132951-92cc4225ed8e/p2p/simulations/adapters/inproc_test.go (about) 1 2 //此源码被清华学神尹成大魔王专业翻译分析并修改 3 //尹成QQ77025077 4 //尹成微信18510341407 5 //尹成所在QQ群721929980 6 //尹成邮箱 yinc13@mails.tsinghua.edu.cn 7 //尹成毕业于清华大学,微软区块链领域全球最有价值专家 8 //https://mvp.microsoft.com/zh-cn/PublicProfile/4033620 9 //版权所有2017 Go Ethereum作者 10 //此文件是Go以太坊库的一部分。 11 // 12 //Go-Ethereum库是免费软件:您可以重新分发它和/或修改 13 //根据GNU发布的较低通用公共许可证的条款 14 //自由软件基金会,或者许可证的第3版,或者 15 //(由您选择)任何更高版本。 16 // 17 //Go以太坊图书馆的发行目的是希望它会有用, 18 //但没有任何保证;甚至没有 19 //适销性或特定用途的适用性。见 20 //GNU较低的通用公共许可证,了解更多详细信息。 21 // 22 //你应该收到一份GNU较低级别的公共许可证副本 23 //以及Go以太坊图书馆。如果没有,请参见<http://www.gnu.org/licenses/>。 24 25 package adapters 26 27 import ( 28 "bytes" 29 "encoding/binary" 30 "fmt" 31 "testing" 32 "time" 33 34 "github.com/ethereum/go-ethereum/p2p/simulations/pipes" 35 ) 36 37 func TestTCPPipe(t *testing.T) { 38 c1, c2, err := pipes.TCPPipe() 39 if err != nil { 40 t.Fatal(err) 41 } 42 43 done := make(chan struct{}) 44 45 go func() { 46 msgs := 50 47 size := 1024 48 for i := 0; i < msgs; i++ { 49 msg := make([]byte, size) 50 _ = binary.PutUvarint(msg, uint64(i)) 51 52 _, err := c1.Write(msg) 53 if err != nil { 54 t.Fatal(err) 55 } 56 } 57 58 for i := 0; i < msgs; i++ { 59 msg := make([]byte, size) 60 _ = binary.PutUvarint(msg, uint64(i)) 61 62 out := make([]byte, size) 63 _, err := c2.Read(out) 64 if err != nil { 65 t.Fatal(err) 66 } 67 68 if !bytes.Equal(msg, out) { 69 t.Fatalf("expected %#v, got %#v", msg, out) 70 } 71 } 72 done <- struct{}{} 73 }() 74 75 select { 76 case <-done: 77 case <-time.After(5 * time.Second): 78 t.Fatal("test timeout") 79 } 80 } 81 82 func TestTCPPipeBidirections(t *testing.T) { 83 c1, c2, err := pipes.TCPPipe() 84 if err != nil { 85 t.Fatal(err) 86 } 87 88 done := make(chan struct{}) 89 90 go func() { 91 msgs := 50 92 size := 7 93 for i := 0; i < msgs; i++ { 94 msg := []byte(fmt.Sprintf("ping %02d", i)) 95 96 _, err := c1.Write(msg) 97 if err != nil { 98 t.Fatal(err) 99 } 100 } 101 102 for i := 0; i < msgs; i++ { 103 expected := []byte(fmt.Sprintf("ping %02d", i)) 104 105 out := make([]byte, size) 106 _, err := c2.Read(out) 107 if err != nil { 108 t.Fatal(err) 109 } 110 111 if !bytes.Equal(expected, out) { 112 t.Fatalf("expected %#v, got %#v", out, expected) 113 } else { 114 msg := []byte(fmt.Sprintf("pong %02d", i)) 115 _, err := c2.Write(msg) 116 if err != nil { 117 t.Fatal(err) 118 } 119 } 120 } 121 122 for i := 0; i < msgs; i++ { 123 expected := []byte(fmt.Sprintf("pong %02d", i)) 124 125 out := make([]byte, size) 126 _, err := c1.Read(out) 127 if err != nil { 128 t.Fatal(err) 129 } 130 131 if !bytes.Equal(expected, out) { 132 t.Fatalf("expected %#v, got %#v", out, expected) 133 } 134 } 135 done <- struct{}{} 136 }() 137 138 select { 139 case <-done: 140 case <-time.After(5 * time.Second): 141 t.Fatal("test timeout") 142 } 143 } 144 145 func TestNetPipe(t *testing.T) { 146 c1, c2, err := pipes.NetPipe() 147 if err != nil { 148 t.Fatal(err) 149 } 150 151 done := make(chan struct{}) 152 153 go func() { 154 msgs := 50 155 size := 1024 156 //网管阻塞,因此写操作是异步发出的。 157 go func() { 158 for i := 0; i < msgs; i++ { 159 msg := make([]byte, size) 160 _ = binary.PutUvarint(msg, uint64(i)) 161 162 _, err := c1.Write(msg) 163 if err != nil { 164 t.Fatal(err) 165 } 166 } 167 }() 168 169 for i := 0; i < msgs; i++ { 170 msg := make([]byte, size) 171 _ = binary.PutUvarint(msg, uint64(i)) 172 173 out := make([]byte, size) 174 _, err := c2.Read(out) 175 if err != nil { 176 t.Fatal(err) 177 } 178 179 if !bytes.Equal(msg, out) { 180 t.Fatalf("expected %#v, got %#v", msg, out) 181 } 182 } 183 184 done <- struct{}{} 185 }() 186 187 select { 188 case <-done: 189 case <-time.After(5 * time.Second): 190 t.Fatal("test timeout") 191 } 192 } 193 194 func TestNetPipeBidirections(t *testing.T) { 195 c1, c2, err := pipes.NetPipe() 196 if err != nil { 197 t.Fatal(err) 198 } 199 200 done := make(chan struct{}) 201 202 go func() { 203 msgs := 1000 204 size := 8 205 pingTemplate := "ping %03d" 206 pongTemplate := "pong %03d" 207 208 //网管阻塞,因此写操作是异步发出的。 209 go func() { 210 for i := 0; i < msgs; i++ { 211 msg := []byte(fmt.Sprintf(pingTemplate, i)) 212 213 _, err := c1.Write(msg) 214 if err != nil { 215 t.Fatal(err) 216 } 217 } 218 }() 219 220 //网管阻塞,因此对pong的读取是异步发出的。 221 go func() { 222 for i := 0; i < msgs; i++ { 223 expected := []byte(fmt.Sprintf(pongTemplate, i)) 224 225 out := make([]byte, size) 226 _, err := c1.Read(out) 227 if err != nil { 228 t.Fatal(err) 229 } 230 231 if !bytes.Equal(expected, out) { 232 t.Fatalf("expected %#v, got %#v", expected, out) 233 } 234 } 235 236 done <- struct{}{} 237 }() 238 239 //期望读取ping,并用pong响应备用连接 240 for i := 0; i < msgs; i++ { 241 expected := []byte(fmt.Sprintf(pingTemplate, i)) 242 243 out := make([]byte, size) 244 _, err := c2.Read(out) 245 if err != nil { 246 t.Fatal(err) 247 } 248 249 if !bytes.Equal(expected, out) { 250 t.Fatalf("expected %#v, got %#v", expected, out) 251 } else { 252 msg := []byte(fmt.Sprintf(pongTemplate, i)) 253 254 _, err := c2.Write(msg) 255 if err != nil { 256 t.Fatal(err) 257 } 258 } 259 } 260 }() 261 262 select { 263 case <-done: 264 case <-time.After(5 * time.Second): 265 t.Fatal("test timeout") 266 } 267 }