normal_test.go 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. package ci
  2. import (
  3. "fmt"
  4. "net/http"
  5. "net/url"
  6. "os"
  7. "strings"
  8. "testing"
  9. "time"
  10. "github.com/gorilla/websocket"
  11. "github.com/stretchr/testify/assert"
  12. "github.com/fatedier/frp/client/proxy"
  13. "github.com/fatedier/frp/server/ports"
  14. "github.com/fatedier/frp/tests/consts"
  15. "github.com/fatedier/frp/tests/mock"
  16. "github.com/fatedier/frp/tests/util"
  17. gnet "github.com/fatedier/golib/net"
  18. )
  19. func TestMain(m *testing.M) {
  20. var err error
  21. tcpEcho1 := mock.NewEchoServer(consts.TEST_TCP_PORT, 1, "")
  22. tcpEcho2 := mock.NewEchoServer(consts.TEST_TCP2_PORT, 2, "")
  23. if err = tcpEcho1.Start(); err != nil {
  24. panic(err)
  25. }
  26. if err = tcpEcho2.Start(); err != nil {
  27. panic(err)
  28. }
  29. go mock.StartUdpEchoServer(consts.TEST_UDP_PORT)
  30. go mock.StartUnixDomainServer(consts.TEST_UNIX_DOMAIN_ADDR)
  31. go mock.StartHttpServer(consts.TEST_HTTP_PORT)
  32. p1 := util.NewProcess(consts.FRPS_BIN_PATH, []string{"-c", "./auto_test_frps.ini"})
  33. if err = p1.Start(); err != nil {
  34. panic(err)
  35. }
  36. time.Sleep(200 * time.Millisecond)
  37. p2 := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", "./auto_test_frpc.ini"})
  38. if err = p2.Start(); err != nil {
  39. panic(err)
  40. }
  41. p3 := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", "./auto_test_frpc_visitor.ini"})
  42. if err = p3.Start(); err != nil {
  43. panic(err)
  44. }
  45. time.Sleep(500 * time.Millisecond)
  46. exitCode := m.Run()
  47. p1.Stop()
  48. p2.Stop()
  49. p3.Stop()
  50. os.Exit(exitCode)
  51. }
  52. func TestTcp(t *testing.T) {
  53. assert := assert.New(t)
  54. // Normal
  55. addr := fmt.Sprintf("127.0.0.1:%d", consts.TEST_TCP_FRP_PORT)
  56. res, err := util.SendTcpMsg(addr, consts.TEST_TCP_ECHO_STR)
  57. assert.NoError(err)
  58. assert.Equal(consts.TEST_TCP_ECHO_STR, res)
  59. // Encrytion and compression
  60. addr = fmt.Sprintf("127.0.0.1:%d", consts.TEST_TCP_EC_FRP_PORT)
  61. res, err = util.SendTcpMsg(addr, consts.TEST_TCP_ECHO_STR)
  62. assert.NoError(err)
  63. assert.Equal(consts.TEST_TCP_ECHO_STR, res)
  64. }
  65. func TestUdp(t *testing.T) {
  66. assert := assert.New(t)
  67. // Normal
  68. addr := fmt.Sprintf("127.0.0.1:%d", consts.TEST_UDP_FRP_PORT)
  69. res, err := util.SendUdpMsg(addr, consts.TEST_UDP_ECHO_STR)
  70. assert.NoError(err)
  71. assert.Equal(consts.TEST_UDP_ECHO_STR, res)
  72. // Encrytion and compression
  73. addr = fmt.Sprintf("127.0.0.1:%d", consts.TEST_UDP_EC_FRP_PORT)
  74. res, err = util.SendUdpMsg(addr, consts.TEST_UDP_ECHO_STR)
  75. assert.NoError(err)
  76. assert.Equal(consts.TEST_UDP_ECHO_STR, res)
  77. }
  78. func TestUnixDomain(t *testing.T) {
  79. assert := assert.New(t)
  80. // Normal
  81. addr := fmt.Sprintf("127.0.0.1:%d", consts.TEST_UNIX_DOMAIN_FRP_PORT)
  82. res, err := util.SendTcpMsg(addr, consts.TEST_UNIX_DOMAIN_STR)
  83. if assert.NoError(err) {
  84. assert.Equal(consts.TEST_UNIX_DOMAIN_STR, res)
  85. }
  86. }
  87. func TestStcp(t *testing.T) {
  88. assert := assert.New(t)
  89. // Normal
  90. addr := fmt.Sprintf("127.0.0.1:%d", consts.TEST_STCP_FRP_PORT)
  91. res, err := util.SendTcpMsg(addr, consts.TEST_STCP_ECHO_STR)
  92. if assert.NoError(err) {
  93. assert.Equal(consts.TEST_STCP_ECHO_STR, res)
  94. }
  95. // Encrytion and compression
  96. addr = fmt.Sprintf("127.0.0.1:%d", consts.TEST_STCP_EC_FRP_PORT)
  97. res, err = util.SendTcpMsg(addr, consts.TEST_STCP_ECHO_STR)
  98. if assert.NoError(err) {
  99. assert.Equal(consts.TEST_STCP_ECHO_STR, res)
  100. }
  101. }
  102. func TestHttp(t *testing.T) {
  103. assert := assert.New(t)
  104. // web01
  105. code, body, _, err := util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "", nil, "")
  106. if assert.NoError(err) {
  107. assert.Equal(200, code)
  108. assert.Equal(consts.TEST_HTTP_NORMAL_STR, body)
  109. }
  110. // web02
  111. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test2.frp.com", nil, "")
  112. if assert.NoError(err) {
  113. assert.Equal(200, code)
  114. assert.Equal(consts.TEST_HTTP_NORMAL_STR, body)
  115. }
  116. // error host header
  117. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "errorhost.frp.com", nil, "")
  118. if assert.NoError(err) {
  119. assert.Equal(404, code)
  120. }
  121. // web03
  122. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test3.frp.com", nil, "")
  123. if assert.NoError(err) {
  124. assert.Equal(200, code)
  125. assert.Equal(consts.TEST_HTTP_NORMAL_STR, body)
  126. }
  127. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d/foo", consts.TEST_HTTP_FRP_PORT), "test3.frp.com", nil, "")
  128. if assert.NoError(err) {
  129. assert.Equal(200, code)
  130. assert.Equal(consts.TEST_HTTP_FOO_STR, body)
  131. }
  132. // web04
  133. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d/bar", consts.TEST_HTTP_FRP_PORT), "test3.frp.com", nil, "")
  134. if assert.NoError(err) {
  135. assert.Equal(200, code)
  136. assert.Equal(consts.TEST_HTTP_BAR_STR, body)
  137. }
  138. // web05
  139. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test5.frp.com", nil, "")
  140. if assert.NoError(err) {
  141. assert.Equal(401, code)
  142. }
  143. headers := make(map[string]string)
  144. headers["Authorization"] = util.BasicAuth("test", "test")
  145. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test5.frp.com", headers, "")
  146. if assert.NoError(err) {
  147. assert.Equal(401, code)
  148. }
  149. // web06
  150. var header http.Header
  151. code, body, header, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test6.frp.com", nil, "")
  152. if assert.NoError(err) {
  153. assert.Equal(200, code)
  154. assert.Equal(consts.TEST_HTTP_NORMAL_STR, body)
  155. assert.Equal("true", header.Get("X-Header-Set"))
  156. }
  157. // subhost01
  158. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test01.sub.com", nil, "")
  159. if assert.NoError(err) {
  160. assert.Equal(200, code)
  161. assert.Equal("test01.sub.com", body)
  162. }
  163. // subhost02
  164. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test02.sub.com", nil, "")
  165. if assert.NoError(err) {
  166. assert.Equal(200, code)
  167. assert.Equal("test02.sub.com", body)
  168. }
  169. }
  170. func TestWebSocket(t *testing.T) {
  171. assert := assert.New(t)
  172. u := url.URL{Scheme: "ws", Host: fmt.Sprintf("%s:%d", "127.0.0.1", consts.TEST_HTTP_FRP_PORT), Path: "/ws"}
  173. c, _, err := websocket.DefaultDialer.Dial(u.String(), nil)
  174. assert.NoError(err)
  175. defer c.Close()
  176. err = c.WriteMessage(websocket.TextMessage, []byte(consts.TEST_HTTP_NORMAL_STR))
  177. assert.NoError(err)
  178. _, msg, err := c.ReadMessage()
  179. assert.NoError(err)
  180. assert.Equal(consts.TEST_HTTP_NORMAL_STR, string(msg))
  181. }
  182. func TestAllowPorts(t *testing.T) {
  183. assert := assert.New(t)
  184. // Port not allowed
  185. status, err := util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyTcpPortNotAllowed)
  186. if assert.NoError(err) {
  187. assert.Equal(proxy.ProxyStatusStartErr, status.Status)
  188. assert.True(strings.Contains(status.Err, ports.ErrPortNotAllowed.Error()))
  189. }
  190. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyUdpPortNotAllowed)
  191. if assert.NoError(err) {
  192. assert.Equal(proxy.ProxyStatusStartErr, status.Status)
  193. assert.True(strings.Contains(status.Err, ports.ErrPortNotAllowed.Error()))
  194. }
  195. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyTcpPortUnavailable)
  196. if assert.NoError(err) {
  197. assert.Equal(proxy.ProxyStatusStartErr, status.Status)
  198. assert.True(strings.Contains(status.Err, ports.ErrPortUnAvailable.Error()))
  199. }
  200. // Port normal
  201. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyTcpPortNormal)
  202. if assert.NoError(err) {
  203. assert.Equal(proxy.ProxyStatusRunning, status.Status)
  204. }
  205. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyUdpPortNormal)
  206. if assert.NoError(err) {
  207. assert.Equal(proxy.ProxyStatusRunning, status.Status)
  208. }
  209. }
  210. func TestRandomPort(t *testing.T) {
  211. assert := assert.New(t)
  212. // tcp
  213. status, err := util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyTcpRandomPort)
  214. if assert.NoError(err) {
  215. addr := status.RemoteAddr
  216. res, err := util.SendTcpMsg(addr, consts.TEST_TCP_ECHO_STR)
  217. assert.NoError(err)
  218. assert.Equal(consts.TEST_TCP_ECHO_STR, res)
  219. }
  220. // udp
  221. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyUdpRandomPort)
  222. if assert.NoError(err) {
  223. addr := status.RemoteAddr
  224. res, err := util.SendUdpMsg(addr, consts.TEST_UDP_ECHO_STR)
  225. assert.NoError(err)
  226. assert.Equal(consts.TEST_UDP_ECHO_STR, res)
  227. }
  228. }
  229. func TestPluginHttpProxy(t *testing.T) {
  230. assert := assert.New(t)
  231. status, err := util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyHttpProxy)
  232. if assert.NoError(err) {
  233. assert.Equal(proxy.ProxyStatusRunning, status.Status)
  234. // http proxy
  235. addr := status.RemoteAddr
  236. code, body, _, err := util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT),
  237. "", nil, "http://"+addr)
  238. if assert.NoError(err) {
  239. assert.Equal(200, code)
  240. assert.Equal(consts.TEST_HTTP_NORMAL_STR, body)
  241. }
  242. // connect method
  243. conn, err := gnet.DialTcpByProxy("http://"+addr, fmt.Sprintf("127.0.0.1:%d", consts.TEST_TCP_FRP_PORT))
  244. if assert.NoError(err) {
  245. res, err := util.SendTcpMsgByConn(conn, consts.TEST_TCP_ECHO_STR)
  246. assert.NoError(err)
  247. assert.Equal(consts.TEST_TCP_ECHO_STR, res)
  248. }
  249. }
  250. }
  251. func TestRangePortsMapping(t *testing.T) {
  252. assert := assert.New(t)
  253. for i := 0; i < 3; i++ {
  254. name := fmt.Sprintf("%s_%d", consts.ProxyRangeTcpPrefix, i)
  255. status, err := util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, name)
  256. if assert.NoError(err) {
  257. assert.Equal(proxy.ProxyStatusRunning, status.Status)
  258. }
  259. }
  260. }
  261. func TestGroup(t *testing.T) {
  262. assert := assert.New(t)
  263. var (
  264. p1 int
  265. p2 int
  266. )
  267. addr := fmt.Sprintf("127.0.0.1:%d", consts.TEST_TCP2_FRP_PORT)
  268. for i := 0; i < 6; i++ {
  269. res, err := util.SendTcpMsg(addr, consts.TEST_TCP_ECHO_STR)
  270. assert.NoError(err)
  271. switch res {
  272. case consts.TEST_TCP_ECHO_STR:
  273. p1++
  274. case consts.TEST_TCP_ECHO_STR + consts.TEST_TCP_ECHO_STR:
  275. p2++
  276. }
  277. }
  278. assert.True(p1 > 0 && p2 > 0, "group proxies load balancing")
  279. }