mux_test.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. package mux
  2. import (
  3. "github.com/cnlh/nps/lib/common"
  4. "github.com/cnlh/nps/vender/github.com/astaxie/beego/logs"
  5. "net"
  6. "net/http"
  7. _ "net/http/pprof"
  8. "sync"
  9. "testing"
  10. "time"
  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. wg := sync.WaitGroup{}
  39. wg.Add(1)
  40. go func() {
  41. _, err = common.CopyBuffer(c2, c)
  42. if err != nil {
  43. c2.Close()
  44. c.Close()
  45. logs.Warn("close npc by copy from nps", err)
  46. }
  47. wg.Done()
  48. }()
  49. wg.Add(1)
  50. go func() {
  51. _, err = common.CopyBuffer(c, c2)
  52. if err != nil {
  53. c2.Close()
  54. c.Close()
  55. logs.Warn("close npc by copy from server", err)
  56. }
  57. wg.Done()
  58. }()
  59. logs.Warn("npc wait")
  60. wg.Wait()
  61. }
  62. }()
  63. go func() {
  64. m1 := NewMux(conn1, "tcp")
  65. l, err := net.Listen("tcp", "127.0.0.1:7777")
  66. if err != nil {
  67. logs.Warn(err)
  68. }
  69. for {
  70. logs.Warn("nps starting accept")
  71. conn, err := l.Accept()
  72. if err != nil {
  73. logs.Warn(err)
  74. continue
  75. }
  76. logs.Warn("nps accept success starting new conn")
  77. tmpCpnn, err := m1.NewConn()
  78. if err != nil {
  79. logs.Warn("nps new conn err ", err)
  80. continue
  81. }
  82. logs.Warn("nps new conn success ", tmpCpnn.connId)
  83. go func() {
  84. _, err := common.CopyBuffer(tmpCpnn, conn)
  85. if err != nil {
  86. conn.Close()
  87. tmpCpnn.Close()
  88. logs.Warn("close nps by copy from user", tmpCpnn.connId)
  89. }
  90. }()
  91. //time.Sleep(time.Second)
  92. _, err = common.CopyBuffer(conn, tmpCpnn)
  93. if err != nil {
  94. conn.Close()
  95. tmpCpnn.Close()
  96. logs.Warn("close nps by copy from npc ", tmpCpnn.connId)
  97. }
  98. }
  99. }()
  100. for {
  101. time.Sleep(time.Second * 5)
  102. }
  103. }
  104. func server() {
  105. var err error
  106. l, err := net.Listen("tcp", "127.0.0.1:9999")
  107. if err != nil {
  108. logs.Warn(err)
  109. }
  110. go func() {
  111. conn1, err = l.Accept()
  112. if err != nil {
  113. logs.Warn(err)
  114. }
  115. }()
  116. return
  117. }
  118. func client() {
  119. var err error
  120. conn2, err = net.Dial("tcp", "127.0.0.1:9999")
  121. if err != nil {
  122. logs.Warn(err)
  123. }
  124. }
  125. func TestNewConn(t *testing.T) {
  126. buf := common.GetBufPoolCopy()
  127. logs.Warn(len(buf), cap(buf))
  128. //b := pool.GetBufPoolCopy()
  129. //b[0] = 1
  130. //b[1] = 2
  131. //b[2] = 3
  132. b := []byte{1, 2, 3}
  133. logs.Warn(copy(buf[:3], b), len(buf), cap(buf))
  134. logs.Warn(len(buf), buf[0])
  135. }