|
|
@ -186,3 +186,95 @@ func TestTLSOverWebsocket(t *testing.T) { |
|
|
|
assert.NoError(err) |
|
|
|
assert.NoError(err) |
|
|
|
assert.Equal(consts.TEST_TCP_ECHO_STR, res) |
|
|
|
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) |
|
|
|
|
|
|
|
} |
|
|
|