mirror of
https://github.com/fatedier/frp.git
synced 2025-01-22 17:42:09 +00:00
add ci case of reload and reconnect
This commit is contained in:
parent
d74b45be5d
commit
57417c83ae
@ -1 +1,3 @@
|
|||||||
package ci
|
package ci
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
@ -4,6 +4,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
@ -20,40 +21,36 @@ import (
|
|||||||
gnet "github.com/fatedier/golib/net"
|
gnet "github.com/fatedier/golib/net"
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func TestMain(m *testing.M) {
|
||||||
go mock.StartTcpEchoServer(consts.TEST_TCP_PORT)
|
go mock.StartTcpEchoServer(consts.TEST_TCP_PORT)
|
||||||
go mock.StartTcpEchoServer2(consts.TEST_TCP2_PORT)
|
go mock.StartTcpEchoServer2(consts.TEST_TCP2_PORT)
|
||||||
go mock.StartUdpEchoServer(consts.TEST_UDP_PORT)
|
go mock.StartUdpEchoServer(consts.TEST_UDP_PORT)
|
||||||
go mock.StartUnixDomainServer(consts.TEST_UNIX_DOMAIN_ADDR)
|
go mock.StartUnixDomainServer(consts.TEST_UNIX_DOMAIN_ADDR)
|
||||||
go mock.StartHttpServer(consts.TEST_HTTP_PORT)
|
go mock.StartHttpServer(consts.TEST_HTTP_PORT)
|
||||||
|
|
||||||
if err := runFrps(); err != nil {
|
var err error
|
||||||
|
p1 := util.NewProcess(consts.FRPS_BIN_PATH, []string{"-c", "./auto_test_frps.ini"})
|
||||||
|
if err = p1.Start(); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
time.Sleep(200 * time.Millisecond)
|
|
||||||
|
|
||||||
if err := runFrpc(); err != nil {
|
time.Sleep(200 * time.Millisecond)
|
||||||
|
p2 := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", "./auto_test_frpc.ini"})
|
||||||
|
if err = p2.Start(); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
if err := runFrpcVisitor(); err != nil {
|
|
||||||
|
p3 := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", "./auto_test_frpc_visitor.ini"})
|
||||||
|
if err = p3.Start(); err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
time.Sleep(500 * time.Millisecond)
|
time.Sleep(500 * time.Millisecond)
|
||||||
}
|
|
||||||
|
|
||||||
func runFrps() error {
|
exitCode := m.Run()
|
||||||
p := util.NewProcess(consts.FRPS_BIN_PATH, []string{"-c", "./auto_test_frps.ini"})
|
p1.Stop()
|
||||||
return p.Start()
|
p2.Stop()
|
||||||
}
|
p3.Stop()
|
||||||
|
os.Exit(exitCode)
|
||||||
func runFrpc() error {
|
|
||||||
p := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", "./auto_test_frpc.ini"})
|
|
||||||
return p.Start()
|
|
||||||
}
|
|
||||||
|
|
||||||
func runFrpcVisitor() error {
|
|
||||||
p := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", "./auto_test_frpc_visitor.ini"})
|
|
||||||
return p.Start()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTcp(t *testing.T) {
|
func TestTcp(t *testing.T) {
|
||||||
|
@ -1 +1,117 @@
|
|||||||
package ci
|
package ci
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/fatedier/frp/tests/config"
|
||||||
|
"github.com/fatedier/frp/tests/consts"
|
||||||
|
"github.com/fatedier/frp/tests/util"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
const FRPS_RECONNECT_CONF = `
|
||||||
|
[common]
|
||||||
|
bind_addr = 0.0.0.0
|
||||||
|
bind_port = 20000
|
||||||
|
log_file = console
|
||||||
|
# debug, info, warn, error
|
||||||
|
log_level = debug
|
||||||
|
token = 123456
|
||||||
|
`
|
||||||
|
|
||||||
|
const FRPC_RECONNECT_CONF = `
|
||||||
|
[common]
|
||||||
|
server_addr = 127.0.0.1
|
||||||
|
server_port = 20000
|
||||||
|
log_file = console
|
||||||
|
# debug, info, warn, error
|
||||||
|
log_level = debug
|
||||||
|
token = 123456
|
||||||
|
admin_port = 21000
|
||||||
|
admin_user = abc
|
||||||
|
admin_pwd = abc
|
||||||
|
|
||||||
|
[tcp]
|
||||||
|
type = tcp
|
||||||
|
local_port = 10701
|
||||||
|
remote_port = 20801
|
||||||
|
`
|
||||||
|
|
||||||
|
func TestReconnect(t *testing.T) {
|
||||||
|
assert := assert.New(t)
|
||||||
|
frpsCfgPath, err := config.GenerateConfigFile(consts.FRPS_NORMAL_CONFIG, FRPS_RECONNECT_CONF)
|
||||||
|
if assert.NoError(err) {
|
||||||
|
defer os.Remove(frpsCfgPath)
|
||||||
|
}
|
||||||
|
|
||||||
|
frpcCfgPath, err := config.GenerateConfigFile(consts.FRPC_NORMAL_CONFIG, FRPC_RECONNECT_CONF)
|
||||||
|
if assert.NoError(err) {
|
||||||
|
defer os.Remove(frpcCfgPath)
|
||||||
|
}
|
||||||
|
|
||||||
|
frpsProcess := util.NewProcess(consts.FRPS_BIN_PATH, []string{"-c", frpsCfgPath})
|
||||||
|
err = frpsProcess.Start()
|
||||||
|
if assert.NoError(err) {
|
||||||
|
defer frpsProcess.Stop()
|
||||||
|
}
|
||||||
|
|
||||||
|
time.Sleep(200 * time.Millisecond)
|
||||||
|
|
||||||
|
frpcProcess := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", frpcCfgPath})
|
||||||
|
err = frpcProcess.Start()
|
||||||
|
if assert.NoError(err) {
|
||||||
|
defer frpcProcess.Stop()
|
||||||
|
}
|
||||||
|
time.Sleep(250 * time.Millisecond)
|
||||||
|
|
||||||
|
// test tcp
|
||||||
|
res, err := util.SendTcpMsg("127.0.0.1:20801", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.NoError(err)
|
||||||
|
assert.Equal(consts.TEST_TCP_ECHO_STR, res)
|
||||||
|
|
||||||
|
// stop frpc
|
||||||
|
frpcProcess.Stop()
|
||||||
|
time.Sleep(100 * time.Millisecond)
|
||||||
|
|
||||||
|
// test tcp, expect failed
|
||||||
|
_, err = util.SendTcpMsg("127.0.0.1:20801", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.Error(err)
|
||||||
|
|
||||||
|
// restart frpc
|
||||||
|
newFrpcProcess := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", frpcCfgPath})
|
||||||
|
err = newFrpcProcess.Start()
|
||||||
|
if assert.NoError(err) {
|
||||||
|
defer newFrpcProcess.Stop()
|
||||||
|
}
|
||||||
|
time.Sleep(250 * time.Millisecond)
|
||||||
|
|
||||||
|
// test tcp
|
||||||
|
res, err = util.SendTcpMsg("127.0.0.1:20801", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.NoError(err)
|
||||||
|
assert.Equal(consts.TEST_TCP_ECHO_STR, res)
|
||||||
|
|
||||||
|
// stop frps
|
||||||
|
frpsProcess.Stop()
|
||||||
|
time.Sleep(100 * time.Millisecond)
|
||||||
|
|
||||||
|
// test tcp, expect failed
|
||||||
|
_, err = util.SendTcpMsg("127.0.0.1:20801", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.Error(err)
|
||||||
|
|
||||||
|
// restart frps
|
||||||
|
newFrpsProcess := util.NewProcess(consts.FRPS_BIN_PATH, []string{"-c", frpsCfgPath})
|
||||||
|
err = newFrpsProcess.Start()
|
||||||
|
if assert.NoError(err) {
|
||||||
|
defer newFrpsProcess.Stop()
|
||||||
|
}
|
||||||
|
|
||||||
|
time.Sleep(2 * time.Second)
|
||||||
|
|
||||||
|
// test tcp
|
||||||
|
res, err = util.SendTcpMsg("127.0.0.1:20801", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.NoError(err)
|
||||||
|
assert.Equal(consts.TEST_TCP_ECHO_STR, res)
|
||||||
|
}
|
||||||
|
@ -12,20 +12,17 @@ import (
|
|||||||
"github.com/fatedier/frp/tests/util"
|
"github.com/fatedier/frp/tests/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
const FRPS_CONF = `
|
const FRPS_RELOAD_CONF = `
|
||||||
[common]
|
[common]
|
||||||
server_addr = 127.0.0.1
|
bind_addr = 0.0.0.0
|
||||||
server_port = 10700
|
bind_port = 20000
|
||||||
log_file = console
|
log_file = console
|
||||||
# debug, info, warn, error
|
# debug, info, warn, error
|
||||||
log_level = debug
|
log_level = debug
|
||||||
token = 123456
|
token = 123456
|
||||||
admin_port = 10600
|
|
||||||
admin_user = abc
|
|
||||||
admin_pwd = abc
|
|
||||||
`
|
`
|
||||||
|
|
||||||
const FRPC_CONF_1 = `
|
const FRPC_RELOAD_CONF_1 = `
|
||||||
[common]
|
[common]
|
||||||
server_addr = 127.0.0.1
|
server_addr = 127.0.0.1
|
||||||
server_port = 20000
|
server_port = 20000
|
||||||
@ -55,7 +52,7 @@ local_port = 10701
|
|||||||
remote_port = 20803
|
remote_port = 20803
|
||||||
`
|
`
|
||||||
|
|
||||||
const FRPC_CONF_2 = `
|
const FRPC_RELOAD_CONF_2 = `
|
||||||
[common]
|
[common]
|
||||||
server_addr = 127.0.0.1
|
server_addr = 127.0.0.1
|
||||||
server_port = 20000
|
server_port = 20000
|
||||||
@ -80,12 +77,12 @@ remote_port = 20902
|
|||||||
|
|
||||||
func TestReload(t *testing.T) {
|
func TestReload(t *testing.T) {
|
||||||
assert := assert.New(t)
|
assert := assert.New(t)
|
||||||
frpsCfgPath, err := config.GenerateConfigFile("./auto_test_frps.ini", FRPS_CONF)
|
frpsCfgPath, err := config.GenerateConfigFile(consts.FRPS_NORMAL_CONFIG, FRPS_RELOAD_CONF)
|
||||||
if assert.NoError(err) {
|
if assert.NoError(err) {
|
||||||
defer os.Remove(frpsCfgPath)
|
defer os.Remove(frpsCfgPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
frpcCfgPath, err := config.GenerateConfigFile("./auto_test_frpc.ini", FRPC_CONF_1)
|
frpcCfgPath, err := config.GenerateConfigFile(consts.FRPC_NORMAL_CONFIG, FRPC_RELOAD_CONF_1)
|
||||||
if assert.NoError(err) {
|
if assert.NoError(err) {
|
||||||
defer os.Remove(frpcCfgPath)
|
defer os.Remove(frpcCfgPath)
|
||||||
}
|
}
|
||||||
@ -104,5 +101,46 @@ func TestReload(t *testing.T) {
|
|||||||
defer frpcProcess.Stop()
|
defer frpcProcess.Stop()
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO
|
time.Sleep(250 * time.Millisecond)
|
||||||
|
|
||||||
|
// test tcp1
|
||||||
|
res, err := util.SendTcpMsg("127.0.0.1:20801", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.NoError(err)
|
||||||
|
assert.Equal(consts.TEST_TCP_ECHO_STR, res)
|
||||||
|
|
||||||
|
// test tcp2
|
||||||
|
res, err = util.SendTcpMsg("127.0.0.1:20802", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.NoError(err)
|
||||||
|
assert.Equal(consts.TEST_TCP_ECHO_STR, res)
|
||||||
|
|
||||||
|
// test tcp3
|
||||||
|
res, err = util.SendTcpMsg("127.0.0.1:20803", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.NoError(err)
|
||||||
|
assert.Equal(consts.TEST_TCP_ECHO_STR, res)
|
||||||
|
|
||||||
|
// reload frpc config
|
||||||
|
frpcCfgPath, err = config.GenerateConfigFile(consts.FRPC_NORMAL_CONFIG, FRPC_RELOAD_CONF_2)
|
||||||
|
assert.NoError(err)
|
||||||
|
err = util.ReloadConf("127.0.0.1:21000", "abc", "abc")
|
||||||
|
assert.NoError(err)
|
||||||
|
|
||||||
|
time.Sleep(time.Second)
|
||||||
|
|
||||||
|
// test tcp1
|
||||||
|
res, err = util.SendTcpMsg("127.0.0.1:20801", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.NoError(err)
|
||||||
|
assert.Equal(consts.TEST_TCP_ECHO_STR, res)
|
||||||
|
|
||||||
|
// test origin tcp2, expect failed
|
||||||
|
res, err = util.SendTcpMsg("127.0.0.1:20802", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.Error(err)
|
||||||
|
|
||||||
|
// test new origin tcp2 with different port
|
||||||
|
res, err = util.SendTcpMsg("127.0.0.1:20902", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.NoError(err)
|
||||||
|
assert.Equal(consts.TEST_TCP_ECHO_STR, res)
|
||||||
|
|
||||||
|
// test tcp3, expect failed
|
||||||
|
res, err = util.SendTcpMsg("127.0.0.1:20803", consts.TEST_TCP_ECHO_STR)
|
||||||
|
assert.Error(err)
|
||||||
}
|
}
|
||||||
|
@ -6,6 +6,9 @@ var (
|
|||||||
FRPS_BIN_PATH = "../../bin/frps"
|
FRPS_BIN_PATH = "../../bin/frps"
|
||||||
FRPC_BIN_PATH = "../../bin/frpc"
|
FRPC_BIN_PATH = "../../bin/frpc"
|
||||||
|
|
||||||
|
FRPS_NORMAL_CONFIG = "./auto_test_frps.ini"
|
||||||
|
FRPC_NORMAL_CONFIG = "./auto_test_frpc.ini"
|
||||||
|
|
||||||
SERVER_ADDR = "127.0.0.1"
|
SERVER_ADDR = "127.0.0.1"
|
||||||
ADMIN_ADDR = "127.0.0.1:10600"
|
ADMIN_ADDR = "127.0.0.1:10600"
|
||||||
ADMIN_USER = "abc"
|
ADMIN_USER = "abc"
|
||||||
|
@ -5,6 +5,7 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -75,6 +76,27 @@ func GetProxyStatus(statusAddr string, user string, passwd string, name string)
|
|||||||
return status, errors.New("no proxy status found")
|
return status, errors.New("no proxy status found")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func ReloadConf(reloadAddr string, user string, passwd string) error {
|
||||||
|
req, err := http.NewRequest("GET", "http://"+reloadAddr+"/api/reload", nil)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
authStr := "Basic " + base64.StdEncoding.EncodeToString([]byte(user+":"+passwd))
|
||||||
|
req.Header.Add("Authorization", authStr)
|
||||||
|
resp, err := http.DefaultClient.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
} else {
|
||||||
|
if resp.StatusCode != 200 {
|
||||||
|
return fmt.Errorf("admin api status code [%d]", resp.StatusCode)
|
||||||
|
}
|
||||||
|
defer resp.Body.Close()
|
||||||
|
io.Copy(ioutil.Discard, resp.Body)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
func SendTcpMsg(addr string, msg string) (res string, err error) {
|
func SendTcpMsg(addr string, msg string) (res string, err error) {
|
||||||
c, err := frpNet.ConnectTcpServer(addr)
|
c, err := frpNet.ConnectTcpServer(addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user