session_test.go 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  1. package yamux
  2. import (
  3. "io"
  4. "sync"
  5. "testing"
  6. "time"
  7. )
  8. type pipeConn struct {
  9. reader *io.PipeReader
  10. writer *io.PipeWriter
  11. }
  12. func (p *pipeConn) Read(b []byte) (int, error) {
  13. return p.reader.Read(b)
  14. }
  15. func (p *pipeConn) Write(b []byte) (int, error) {
  16. return p.writer.Write(b)
  17. }
  18. func (p *pipeConn) Close() error {
  19. p.reader.Close()
  20. return p.writer.Close()
  21. }
  22. func testConn() (io.ReadWriteCloser, io.ReadWriteCloser) {
  23. read1, write1 := io.Pipe()
  24. read2, write2 := io.Pipe()
  25. return &pipeConn{read1, write2}, &pipeConn{read2, write1}
  26. }
  27. func testClientServer() (*Session, *Session) {
  28. conn1, conn2 := testConn()
  29. client, _ := Client(conn1, nil)
  30. server, _ := Server(conn2, nil)
  31. return client, server
  32. }
  33. func TestPing(t *testing.T) {
  34. client, server := testClientServer()
  35. defer client.Close()
  36. defer server.Close()
  37. rtt, err := client.Ping()
  38. if err != nil {
  39. t.Fatalf("err: %v", err)
  40. }
  41. if rtt == 0 {
  42. t.Fatalf("bad: %v", rtt)
  43. }
  44. rtt, err = server.Ping()
  45. if err != nil {
  46. t.Fatalf("err: %v", err)
  47. }
  48. if rtt == 0 {
  49. t.Fatalf("bad: %v", rtt)
  50. }
  51. }
  52. func TestAccept(t *testing.T) {
  53. client, server := testClientServer()
  54. defer client.Close()
  55. defer server.Close()
  56. wg := &sync.WaitGroup{}
  57. wg.Add(4)
  58. go func() {
  59. defer wg.Done()
  60. stream, err := server.AcceptStream()
  61. if err != nil {
  62. t.Fatalf("err: %v", err)
  63. }
  64. if id := stream.StreamID(); id != 1 {
  65. t.Fatalf("bad: %v", id)
  66. }
  67. if err := stream.Close(); err != nil {
  68. t.Fatalf("err: %v", err)
  69. }
  70. }()
  71. go func() {
  72. defer wg.Done()
  73. stream, err := client.AcceptStream()
  74. if err != nil {
  75. t.Fatalf("err: %v", err)
  76. }
  77. if id := stream.StreamID(); id != 2 {
  78. t.Fatalf("bad: %v", id)
  79. }
  80. if err := stream.Close(); err != nil {
  81. t.Fatalf("err: %v", err)
  82. }
  83. }()
  84. go func() {
  85. defer wg.Done()
  86. stream, err := server.Open()
  87. if err != nil {
  88. t.Fatalf("err: %v", err)
  89. }
  90. if id := stream.StreamID(); id != 2 {
  91. t.Fatalf("bad: %v", id)
  92. }
  93. if err := stream.Close(); err != nil {
  94. t.Fatalf("err: %v", err)
  95. }
  96. }()
  97. go func() {
  98. defer wg.Done()
  99. stream, err := client.Open()
  100. if err != nil {
  101. t.Fatalf("err: %v", err)
  102. }
  103. if id := stream.StreamID(); id != 1 {
  104. t.Fatalf("bad: %v", id)
  105. }
  106. if err := stream.Close(); err != nil {
  107. t.Fatalf("err: %v", err)
  108. }
  109. }()
  110. doneCh := make(chan struct{})
  111. go func() {
  112. wg.Wait()
  113. close(doneCh)
  114. }()
  115. select {
  116. case <-doneCh:
  117. case <-time.After(time.Second):
  118. panic("timeout")
  119. }
  120. }
  121. func TestSendData_Small(t *testing.T) {
  122. client, server := testClientServer()
  123. defer client.Close()
  124. defer server.Close()
  125. wg := &sync.WaitGroup{}
  126. wg.Add(2)
  127. go func() {
  128. defer wg.Done()
  129. stream, err := server.AcceptStream()
  130. if err != nil {
  131. t.Fatalf("err: %v", err)
  132. }
  133. buf := make([]byte, 4)
  134. for i := 0; i < 1000; i++ {
  135. n, err := stream.Read(buf)
  136. if err != nil {
  137. t.Fatalf("err: %v", err)
  138. }
  139. if n != 4 {
  140. t.Fatalf("short read: %d", n)
  141. }
  142. if string(buf) != "test" {
  143. t.Fatalf("bad: %s", buf)
  144. }
  145. }
  146. if err := stream.Close(); err != nil {
  147. t.Fatalf("err: %v", err)
  148. }
  149. }()
  150. go func() {
  151. defer wg.Done()
  152. stream, err := client.Open()
  153. if err != nil {
  154. t.Fatalf("err: %v", err)
  155. }
  156. for i := 0; i < 1000; i++ {
  157. n, err := stream.Write([]byte("test"))
  158. if err != nil {
  159. t.Fatalf("err: %v", err)
  160. }
  161. if n != 4 {
  162. t.Fatalf("short write %d", n)
  163. }
  164. }
  165. if err := stream.Close(); err != nil {
  166. t.Fatalf("err: %v", err)
  167. }
  168. }()
  169. doneCh := make(chan struct{})
  170. go func() {
  171. wg.Wait()
  172. close(doneCh)
  173. }()
  174. select {
  175. case <-doneCh:
  176. case <-time.After(time.Second):
  177. panic("timeout")
  178. }
  179. }
  180. func TestSendData_Large(t *testing.T) {
  181. client, server := testClientServer()
  182. defer client.Close()
  183. defer server.Close()
  184. data := make([]byte, 512*1024)
  185. for idx := range data {
  186. data[idx] = byte(idx % 256)
  187. }
  188. wg := &sync.WaitGroup{}
  189. wg.Add(2)
  190. go func() {
  191. defer wg.Done()
  192. stream, err := server.AcceptStream()
  193. if err != nil {
  194. t.Fatalf("err: %v", err)
  195. }
  196. buf := make([]byte, 4*1024)
  197. for i := 0; i < 128; i++ {
  198. n, err := stream.Read(buf)
  199. if err != nil {
  200. t.Fatalf("err: %v", err)
  201. }
  202. if n != 4*1024 {
  203. t.Fatalf("short read: %d", n)
  204. }
  205. for idx := range buf {
  206. if buf[idx] != byte(idx%256) {
  207. t.Fatalf("bad: %v %v %v", i, idx, buf[idx])
  208. }
  209. }
  210. }
  211. if err := stream.Close(); err != nil {
  212. t.Fatalf("err: %v", err)
  213. }
  214. }()
  215. go func() {
  216. defer wg.Done()
  217. stream, err := client.Open()
  218. if err != nil {
  219. t.Fatalf("err: %v", err)
  220. }
  221. n, err := stream.Write(data)
  222. if err != nil {
  223. t.Fatalf("err: %v", err)
  224. }
  225. if n != len(data) {
  226. t.Fatalf("short write %d", n)
  227. }
  228. if err := stream.Close(); err != nil {
  229. t.Fatalf("err: %v", err)
  230. }
  231. }()
  232. doneCh := make(chan struct{})
  233. go func() {
  234. wg.Wait()
  235. close(doneCh)
  236. }()
  237. select {
  238. case <-doneCh:
  239. case <-time.After(time.Second):
  240. panic("timeout")
  241. }
  242. }
  243. func TestGoAway(t *testing.T) {
  244. client, server := testClientServer()
  245. defer client.Close()
  246. defer server.Close()
  247. if err := server.GoAway(); err != nil {
  248. t.Fatalf("err: %v", err)
  249. }
  250. _, err := client.Open()
  251. if err != ErrRemoteGoAway {
  252. t.Fatalf("err: %v", err)
  253. }
  254. }