1
0

normal_test.go 11 KB

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