normal_test.go 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353
  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. // wildcard_http
  158. // test.frp1.com match *.frp1.com
  159. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test.frp1.com", nil, "")
  160. if assert.NoError(err) {
  161. assert.Equal(200, code)
  162. assert.Equal(consts.TEST_HTTP_NORMAL_STR, body)
  163. }
  164. // new.test.frp1.com also match *.frp1.com
  165. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "new.test.frp1.com", nil, "")
  166. if assert.NoError(err) {
  167. assert.Equal(200, code)
  168. assert.Equal(consts.TEST_HTTP_NORMAL_STR, body)
  169. }
  170. // subhost01
  171. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test01.sub.com", nil, "")
  172. if assert.NoError(err) {
  173. assert.Equal(200, code)
  174. assert.Equal("test01.sub.com", body)
  175. }
  176. // subhost02
  177. code, body, _, err = util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT), "test02.sub.com", nil, "")
  178. if assert.NoError(err) {
  179. assert.Equal(200, code)
  180. assert.Equal("test02.sub.com", body)
  181. }
  182. }
  183. func TestTcpMux(t *testing.T) {
  184. assert := assert.New(t)
  185. conn, err := gnet.DialTcpByProxy(fmt.Sprintf("http://%s:%d", "127.0.0.1", consts.TEST_TCP_MUX_FRP_PORT), "tunnel1")
  186. if assert.NoError(err) {
  187. res, err := util.SendTcpMsgByConn(conn, consts.TEST_TCP_ECHO_STR)
  188. assert.NoError(err)
  189. assert.Equal(consts.TEST_TCP_ECHO_STR, res)
  190. }
  191. }
  192. func TestWebSocket(t *testing.T) {
  193. assert := assert.New(t)
  194. u := url.URL{Scheme: "ws", Host: fmt.Sprintf("%s:%d", "127.0.0.1", consts.TEST_HTTP_FRP_PORT), Path: "/ws"}
  195. c, _, err := websocket.DefaultDialer.Dial(u.String(), nil)
  196. assert.NoError(err)
  197. defer c.Close()
  198. err = c.WriteMessage(websocket.TextMessage, []byte(consts.TEST_HTTP_NORMAL_STR))
  199. assert.NoError(err)
  200. _, msg, err := c.ReadMessage()
  201. assert.NoError(err)
  202. assert.Equal(consts.TEST_HTTP_NORMAL_STR, string(msg))
  203. }
  204. func TestAllowPorts(t *testing.T) {
  205. assert := assert.New(t)
  206. // Port not allowed
  207. status, err := util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyTcpPortNotAllowed)
  208. if assert.NoError(err) {
  209. assert.Equal(proxy.ProxyStatusStartErr, status.Status)
  210. assert.True(strings.Contains(status.Err, ports.ErrPortNotAllowed.Error()))
  211. }
  212. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyUdpPortNotAllowed)
  213. if assert.NoError(err) {
  214. assert.Equal(proxy.ProxyStatusStartErr, status.Status)
  215. assert.True(strings.Contains(status.Err, ports.ErrPortNotAllowed.Error()))
  216. }
  217. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyTcpPortUnavailable)
  218. if assert.NoError(err) {
  219. assert.Equal(proxy.ProxyStatusStartErr, status.Status)
  220. assert.True(strings.Contains(status.Err, ports.ErrPortUnAvailable.Error()))
  221. }
  222. // Port normal
  223. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyTcpPortNormal)
  224. if assert.NoError(err) {
  225. assert.Equal(proxy.ProxyStatusRunning, status.Status)
  226. }
  227. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyUdpPortNormal)
  228. if assert.NoError(err) {
  229. assert.Equal(proxy.ProxyStatusRunning, status.Status)
  230. }
  231. }
  232. func TestRandomPort(t *testing.T) {
  233. assert := assert.New(t)
  234. // tcp
  235. status, err := util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyTcpRandomPort)
  236. if assert.NoError(err) {
  237. addr := status.RemoteAddr
  238. res, err := util.SendTcpMsg(addr, consts.TEST_TCP_ECHO_STR)
  239. assert.NoError(err)
  240. assert.Equal(consts.TEST_TCP_ECHO_STR, res)
  241. }
  242. // udp
  243. status, err = util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyUdpRandomPort)
  244. if assert.NoError(err) {
  245. addr := status.RemoteAddr
  246. res, err := util.SendUdpMsg(addr, consts.TEST_UDP_ECHO_STR)
  247. assert.NoError(err)
  248. assert.Equal(consts.TEST_UDP_ECHO_STR, res)
  249. }
  250. }
  251. func TestPluginHttpProxy(t *testing.T) {
  252. assert := assert.New(t)
  253. status, err := util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, consts.ProxyHttpProxy)
  254. if assert.NoError(err) {
  255. assert.Equal(proxy.ProxyStatusRunning, status.Status)
  256. // http proxy
  257. addr := status.RemoteAddr
  258. code, body, _, err := util.SendHttpMsg("GET", fmt.Sprintf("http://127.0.0.1:%d", consts.TEST_HTTP_FRP_PORT),
  259. "", nil, "http://"+addr)
  260. if assert.NoError(err) {
  261. assert.Equal(200, code)
  262. assert.Equal(consts.TEST_HTTP_NORMAL_STR, body)
  263. }
  264. // connect method
  265. conn, err := gnet.DialTcpByProxy("http://"+addr, fmt.Sprintf("127.0.0.1:%d", consts.TEST_TCP_FRP_PORT))
  266. if assert.NoError(err) {
  267. res, err := util.SendTcpMsgByConn(conn, consts.TEST_TCP_ECHO_STR)
  268. assert.NoError(err)
  269. assert.Equal(consts.TEST_TCP_ECHO_STR, res)
  270. }
  271. }
  272. }
  273. func TestRangePortsMapping(t *testing.T) {
  274. assert := assert.New(t)
  275. for i := 0; i < 3; i++ {
  276. name := fmt.Sprintf("%s_%d", consts.ProxyRangeTcpPrefix, i)
  277. status, err := util.GetProxyStatus(consts.ADMIN_ADDR, consts.ADMIN_USER, consts.ADMIN_PWD, name)
  278. if assert.NoError(err) {
  279. assert.Equal(proxy.ProxyStatusRunning, status.Status)
  280. }
  281. }
  282. }
  283. func TestGroup(t *testing.T) {
  284. assert := assert.New(t)
  285. var (
  286. p1 int
  287. p2 int
  288. )
  289. addr := fmt.Sprintf("127.0.0.1:%d", consts.TEST_TCP2_FRP_PORT)
  290. for i := 0; i < 6; i++ {
  291. res, err := util.SendTcpMsg(addr, consts.TEST_TCP_ECHO_STR)
  292. assert.NoError(err)
  293. switch res {
  294. case consts.TEST_TCP_ECHO_STR:
  295. p1++
  296. case consts.TEST_TCP_ECHO_STR + consts.TEST_TCP_ECHO_STR:
  297. p2++
  298. }
  299. }
  300. assert.True(p1 > 0 && p2 > 0, "group proxies load balancing")
  301. }