mux_test.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. package mux
  2. import (
  3. "net"
  4. "net/http"
  5. _ "net/http/pprof"
  6. "sync"
  7. "testing"
  8. "time"
  9. "github.com/astaxie/beego/logs"
  10. "github.com/cnlh/nps/lib/common"
  11. )
  12. var conn1 net.Conn
  13. var conn2 net.Conn
  14. func TestNewMux(t *testing.T) {
  15. go func() {
  16. http.ListenAndServe("0.0.0.0:8889", nil)
  17. }()
  18. logs.EnableFuncCallDepth(true)
  19. logs.SetLogFuncCallDepth(3)
  20. server()
  21. client()
  22. time.Sleep(time.Second * 3)
  23. go func() {
  24. m2 := NewMux(conn2, "tcp")
  25. for {
  26. logs.Warn("npc starting accept")
  27. c, err := m2.Accept()
  28. if err != nil {
  29. logs.Warn(err)
  30. continue
  31. }
  32. logs.Warn("npc accept success ")
  33. c2, err := net.Dial("tcp", "127.0.0.1:80")
  34. if err != nil {
  35. logs.Warn(err)
  36. continue
  37. }
  38. go func(c2 net.Conn, c net.Conn) {
  39. wg := sync.WaitGroup{}
  40. wg.Add(1)
  41. go func() {
  42. _, err = common.CopyBuffer(c2, c)
  43. if err != nil {
  44. c2.Close()
  45. c.Close()
  46. logs.Warn("close npc by copy from nps", err)
  47. }
  48. wg.Done()
  49. }()
  50. wg.Add(1)
  51. go func() {
  52. _, err = common.CopyBuffer(c, c2)
  53. if err != nil {
  54. c2.Close()
  55. c.Close()
  56. logs.Warn("close npc by copy from server", err)
  57. }
  58. wg.Done()
  59. }()
  60. logs.Warn("npc wait")
  61. wg.Wait()
  62. }(c2, c)
  63. }
  64. }()
  65. go func() {
  66. m1 := NewMux(conn1, "tcp")
  67. l, err := net.Listen("tcp", "127.0.0.1:7777")
  68. if err != nil {
  69. logs.Warn(err)
  70. }
  71. for {
  72. logs.Warn("nps starting accept")
  73. conn, err := l.Accept()
  74. if err != nil {
  75. logs.Warn(err)
  76. continue
  77. }
  78. logs.Warn("nps accept success starting new conn")
  79. tmpCpnn, err := m1.NewConn()
  80. if err != nil {
  81. logs.Warn("nps new conn err ", err)
  82. continue
  83. }
  84. logs.Warn("nps new conn success ", tmpCpnn.connId)
  85. go func(tmpCpnn net.Conn, conn net.Conn) {
  86. go func() {
  87. _, err := common.CopyBuffer(tmpCpnn, conn)
  88. if err != nil {
  89. conn.Close()
  90. tmpCpnn.Close()
  91. logs.Warn("close nps by copy from user")
  92. }
  93. }()
  94. //time.Sleep(time.Second)
  95. _, err = common.CopyBuffer(conn, tmpCpnn)
  96. if err != nil {
  97. conn.Close()
  98. tmpCpnn.Close()
  99. logs.Warn("close nps by copy from npc ")
  100. }
  101. }(tmpCpnn, conn)
  102. }
  103. }()
  104. for {
  105. time.Sleep(time.Second * 5)
  106. }
  107. }
  108. func server() {
  109. var err error
  110. l, err := net.Listen("tcp", "127.0.0.1:9999")
  111. if err != nil {
  112. logs.Warn(err)
  113. }
  114. go func() {
  115. conn1, err = l.Accept()
  116. if err != nil {
  117. logs.Warn(err)
  118. }
  119. }()
  120. return
  121. }
  122. func client() {
  123. var err error
  124. conn2, err = net.Dial("tcp", "127.0.0.1:9999")
  125. if err != nil {
  126. logs.Warn(err)
  127. }
  128. }
  129. func TestNewConn(t *testing.T) {
  130. buf := common.GetBufPoolCopy()
  131. logs.Warn(len(buf), cap(buf))
  132. //b := pool.GetBufPoolCopy()
  133. //b[0] = 1
  134. //b[1] = 2
  135. //b[2] = 3
  136. b := []byte{1, 2, 3}
  137. logs.Warn(copy(buf[:3], b), len(buf), cap(buf))
  138. logs.Warn(len(buf), buf[0])
  139. }