mirror of https://github.com/fatedier/frp.git
update e2e tests (#1973)
parent
c9fe23eb10
commit
48fa618c34
@ -1,72 +0,0 @@
|
|||||||
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_TOKEN_TCP_CONF = `
|
|
||||||
[common]
|
|
||||||
bind_addr = 0.0.0.0
|
|
||||||
bind_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
authentication_method = token
|
|
||||||
token = 123456
|
|
||||||
`
|
|
||||||
|
|
||||||
const FRPC_TOKEN_TCP_CONF = `
|
|
||||||
[common]
|
|
||||||
server_addr = 127.0.0.1
|
|
||||||
server_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
authentication_method = token
|
|
||||||
token = 123456
|
|
||||||
protocol = tcp
|
|
||||||
|
|
||||||
[tcp]
|
|
||||||
type = tcp
|
|
||||||
local_port = 10701
|
|
||||||
remote_port = 20801
|
|
||||||
`
|
|
||||||
|
|
||||||
func TestTCPWithTokenAuthentication(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
frpsCfgPath, err := config.GenerateConfigFile(consts.FRPS_NORMAL_CONFIG, FRPS_TOKEN_TCP_CONF)
|
|
||||||
if assert.NoError(err) {
|
|
||||||
defer os.Remove(frpsCfgPath)
|
|
||||||
}
|
|
||||||
|
|
||||||
frpcCfgPath, err := config.GenerateConfigFile(consts.FRPC_NORMAL_CONFIG, FRPC_TOKEN_TCP_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(500 * 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)
|
|
||||||
}
|
|
@ -1,280 +0,0 @@
|
|||||||
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_TLS_TCP_CONF = `
|
|
||||||
[common]
|
|
||||||
bind_addr = 0.0.0.0
|
|
||||||
bind_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
token = 123456
|
|
||||||
`
|
|
||||||
|
|
||||||
const FRPC_TLS_TCP_CONF = `
|
|
||||||
[common]
|
|
||||||
server_addr = 127.0.0.1
|
|
||||||
server_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
token = 123456
|
|
||||||
protocol = tcp
|
|
||||||
tls_enable = true
|
|
||||||
|
|
||||||
[tcp]
|
|
||||||
type = tcp
|
|
||||||
local_port = 10701
|
|
||||||
remote_port = 20801
|
|
||||||
`
|
|
||||||
|
|
||||||
func TestTLSOverTCP(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
frpsCfgPath, err := config.GenerateConfigFile(consts.FRPS_NORMAL_CONFIG, FRPS_TLS_TCP_CONF)
|
|
||||||
if assert.NoError(err) {
|
|
||||||
defer os.Remove(frpsCfgPath)
|
|
||||||
}
|
|
||||||
|
|
||||||
frpcCfgPath, err := config.GenerateConfigFile(consts.FRPC_NORMAL_CONFIG, FRPC_TLS_TCP_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(500 * 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)
|
|
||||||
}
|
|
||||||
|
|
||||||
const FRPS_TLS_KCP_CONF = `
|
|
||||||
[common]
|
|
||||||
bind_addr = 0.0.0.0
|
|
||||||
bind_port = 20000
|
|
||||||
kcp_bind_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
token = 123456
|
|
||||||
`
|
|
||||||
|
|
||||||
const FRPC_TLS_KCP_CONF = `
|
|
||||||
[common]
|
|
||||||
server_addr = 127.0.0.1
|
|
||||||
server_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
token = 123456
|
|
||||||
protocol = kcp
|
|
||||||
tls_enable = true
|
|
||||||
|
|
||||||
[tcp]
|
|
||||||
type = tcp
|
|
||||||
local_port = 10701
|
|
||||||
remote_port = 20801
|
|
||||||
`
|
|
||||||
|
|
||||||
func TestTLSOverKCP(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
frpsCfgPath, err := config.GenerateConfigFile(consts.FRPS_NORMAL_CONFIG, FRPS_TLS_KCP_CONF)
|
|
||||||
if assert.NoError(err) {
|
|
||||||
defer os.Remove(frpsCfgPath)
|
|
||||||
}
|
|
||||||
|
|
||||||
frpcCfgPath, err := config.GenerateConfigFile(consts.FRPC_NORMAL_CONFIG, FRPC_TLS_KCP_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(500 * 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)
|
|
||||||
}
|
|
||||||
|
|
||||||
const FRPS_TLS_WS_CONF = `
|
|
||||||
[common]
|
|
||||||
bind_addr = 0.0.0.0
|
|
||||||
bind_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
token = 123456
|
|
||||||
`
|
|
||||||
|
|
||||||
const FRPC_TLS_WS_CONF = `
|
|
||||||
[common]
|
|
||||||
server_addr = 127.0.0.1
|
|
||||||
server_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
token = 123456
|
|
||||||
protocol = websocket
|
|
||||||
tls_enable = true
|
|
||||||
|
|
||||||
[tcp]
|
|
||||||
type = tcp
|
|
||||||
local_port = 10701
|
|
||||||
remote_port = 20801
|
|
||||||
`
|
|
||||||
|
|
||||||
func TestTLSOverWebsocket(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
frpsCfgPath, err := config.GenerateConfigFile(consts.FRPS_NORMAL_CONFIG, FRPS_TLS_WS_CONF)
|
|
||||||
if assert.NoError(err) {
|
|
||||||
defer os.Remove(frpsCfgPath)
|
|
||||||
}
|
|
||||||
|
|
||||||
frpcCfgPath, err := config.GenerateConfigFile(consts.FRPC_NORMAL_CONFIG, FRPC_TLS_WS_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(500 * 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)
|
|
||||||
}
|
|
||||||
|
|
||||||
const FRPS_TLS_ONLY_TCP_CONF = `
|
|
||||||
[common]
|
|
||||||
bind_addr = 0.0.0.0
|
|
||||||
bind_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
token = 123456
|
|
||||||
tls_only = true
|
|
||||||
`
|
|
||||||
|
|
||||||
const FRPC_TLS_ONLY_TCP_CONF = `
|
|
||||||
[common]
|
|
||||||
server_addr = 127.0.0.1
|
|
||||||
server_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
token = 123456
|
|
||||||
protocol = tcp
|
|
||||||
tls_enable = true
|
|
||||||
|
|
||||||
[tcp]
|
|
||||||
type = tcp
|
|
||||||
local_port = 10701
|
|
||||||
remote_port = 20801
|
|
||||||
`
|
|
||||||
|
|
||||||
const FRPC_TLS_ONLY_NO_TLS_TCP_CONF = `
|
|
||||||
[common]
|
|
||||||
server_addr = 127.0.0.1
|
|
||||||
server_port = 20000
|
|
||||||
log_file = console
|
|
||||||
log_level = debug
|
|
||||||
token = 123456
|
|
||||||
protocol = tcp
|
|
||||||
tls_enable = false
|
|
||||||
|
|
||||||
[tcp]
|
|
||||||
type = tcp
|
|
||||||
local_port = 10701
|
|
||||||
remote_port = 20802
|
|
||||||
`
|
|
||||||
|
|
||||||
func TestTLSOnlyOverTCP(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
frpsCfgPath, err := config.GenerateConfigFile(consts.FRPS_NORMAL_CONFIG, FRPS_TLS_ONLY_TCP_CONF)
|
|
||||||
if assert.NoError(err) {
|
|
||||||
defer os.Remove(frpsCfgPath)
|
|
||||||
}
|
|
||||||
|
|
||||||
frpcWithTLSCfgPath, err := config.GenerateConfigFile(consts.FRPC_NORMAL_CONFIG, FRPC_TLS_ONLY_TCP_CONF)
|
|
||||||
if assert.NoError(err) {
|
|
||||||
defer os.Remove(frpcWithTLSCfgPath)
|
|
||||||
}
|
|
||||||
|
|
||||||
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)
|
|
||||||
|
|
||||||
frpcProcessWithTLS := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", frpcWithTLSCfgPath})
|
|
||||||
err = frpcProcessWithTLS.Start()
|
|
||||||
if assert.NoError(err) {
|
|
||||||
defer frpcProcessWithTLS.Stop()
|
|
||||||
}
|
|
||||||
time.Sleep(500 * time.Millisecond)
|
|
||||||
|
|
||||||
// test tcp over TLS
|
|
||||||
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)
|
|
||||||
frpcProcessWithTLS.Stop()
|
|
||||||
|
|
||||||
frpcWithoutTLSCfgPath, err := config.GenerateConfigFile(consts.FRPC_NORMAL_CONFIG, FRPC_TLS_ONLY_NO_TLS_TCP_CONF)
|
|
||||||
if assert.NoError(err) {
|
|
||||||
defer os.Remove(frpcWithTLSCfgPath)
|
|
||||||
}
|
|
||||||
|
|
||||||
frpcProcessWithoutTLS := util.NewProcess(consts.FRPC_BIN_PATH, []string{"-c", frpcWithoutTLSCfgPath})
|
|
||||||
err = frpcProcessWithoutTLS.Start()
|
|
||||||
if assert.NoError(err) {
|
|
||||||
defer frpcProcessWithoutTLS.Stop()
|
|
||||||
}
|
|
||||||
time.Sleep(500 * time.Millisecond)
|
|
||||||
|
|
||||||
// test tcp without TLS
|
|
||||||
_, err = util.SendTCPMsg("127.0.0.1:20802", consts.TEST_TCP_ECHO_STR)
|
|
||||||
assert.Error(err)
|
|
||||||
}
|
|
Loading…
Reference in New Issue