2021-06-18 08:48:36 +00:00
|
|
|
package basic
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
2023-02-27 06:44:16 +00:00
|
|
|
"github.com/onsi/ginkgo/v2"
|
2022-08-28 17:02:53 +00:00
|
|
|
|
2023-09-15 02:33:32 +00:00
|
|
|
clientsdk "github.com/fatedier/frp/pkg/sdk/client"
|
2021-06-18 08:48:36 +00:00
|
|
|
"github.com/fatedier/frp/test/e2e/framework"
|
|
|
|
"github.com/fatedier/frp/test/e2e/framework/consts"
|
2021-11-23 06:14:27 +00:00
|
|
|
"github.com/fatedier/frp/test/e2e/pkg/request"
|
2021-06-18 08:48:36 +00:00
|
|
|
)
|
|
|
|
|
2022-08-28 17:02:53 +00:00
|
|
|
var _ = ginkgo.Describe("[Feature: ClientManage]", func() {
|
2021-06-18 08:48:36 +00:00
|
|
|
f := framework.NewDefaultFramework()
|
|
|
|
|
2022-08-28 17:02:53 +00:00
|
|
|
ginkgo.It("Update && Reload API", func() {
|
2023-09-13 08:32:39 +00:00
|
|
|
serverConf := consts.LegacyDefaultServerConfig
|
2021-06-18 08:48:36 +00:00
|
|
|
|
|
|
|
adminPort := f.AllocPort()
|
|
|
|
|
|
|
|
p1Port := f.AllocPort()
|
|
|
|
p2Port := f.AllocPort()
|
|
|
|
p3Port := f.AllocPort()
|
|
|
|
|
2023-09-13 08:32:39 +00:00
|
|
|
clientConf := consts.LegacyDefaultClientConfig + fmt.Sprintf(`
|
2021-06-18 08:48:36 +00:00
|
|
|
admin_port = %d
|
|
|
|
|
|
|
|
[p1]
|
|
|
|
type = tcp
|
|
|
|
local_port = {{ .%s }}
|
|
|
|
remote_port = %d
|
|
|
|
|
|
|
|
[p2]
|
|
|
|
type = tcp
|
|
|
|
local_port = {{ .%s }}
|
|
|
|
remote_port = %d
|
|
|
|
|
|
|
|
[p3]
|
|
|
|
type = tcp
|
|
|
|
local_port = {{ .%s }}
|
|
|
|
remote_port = %d
|
|
|
|
`, adminPort,
|
|
|
|
framework.TCPEchoServerPort, p1Port,
|
|
|
|
framework.TCPEchoServerPort, p2Port,
|
|
|
|
framework.TCPEchoServerPort, p3Port)
|
|
|
|
|
|
|
|
f.RunProcesses([]string{serverConf}, []string{clientConf})
|
|
|
|
|
|
|
|
framework.NewRequestExpect(f).Port(p1Port).Ensure()
|
|
|
|
framework.NewRequestExpect(f).Port(p2Port).Ensure()
|
|
|
|
framework.NewRequestExpect(f).Port(p3Port).Ensure()
|
|
|
|
|
|
|
|
client := clientsdk.New("127.0.0.1", adminPort)
|
|
|
|
conf, err := client.GetConfig()
|
|
|
|
framework.ExpectNoError(err)
|
|
|
|
|
|
|
|
newP2Port := f.AllocPort()
|
|
|
|
// change p2 port and remove p3 proxy
|
|
|
|
newClientConf := strings.ReplaceAll(conf, strconv.Itoa(p2Port), strconv.Itoa(newP2Port))
|
|
|
|
p3Index := strings.Index(newClientConf, "[p3]")
|
2022-08-28 17:02:53 +00:00
|
|
|
if p3Index >= 0 {
|
|
|
|
newClientConf = newClientConf[:p3Index]
|
|
|
|
}
|
2021-06-18 08:48:36 +00:00
|
|
|
|
|
|
|
err = client.UpdateConfig(newClientConf)
|
|
|
|
framework.ExpectNoError(err)
|
|
|
|
|
|
|
|
err = client.Reload()
|
|
|
|
framework.ExpectNoError(err)
|
|
|
|
time.Sleep(time.Second)
|
|
|
|
|
|
|
|
framework.NewRequestExpect(f).Port(p1Port).Explain("p1 port").Ensure()
|
|
|
|
framework.NewRequestExpect(f).Port(p2Port).Explain("original p2 port").ExpectError(true).Ensure()
|
|
|
|
framework.NewRequestExpect(f).Port(newP2Port).Explain("new p2 port").Ensure()
|
|
|
|
framework.NewRequestExpect(f).Port(p3Port).Explain("p3 port").ExpectError(true).Ensure()
|
|
|
|
})
|
2021-11-23 06:14:27 +00:00
|
|
|
|
2022-08-28 17:02:53 +00:00
|
|
|
ginkgo.It("healthz", func() {
|
2023-09-13 08:32:39 +00:00
|
|
|
serverConf := consts.LegacyDefaultServerConfig
|
2021-11-23 06:14:27 +00:00
|
|
|
|
|
|
|
dashboardPort := f.AllocPort()
|
2023-09-13 08:32:39 +00:00
|
|
|
clientConf := consts.LegacyDefaultClientConfig + fmt.Sprintf(`
|
2021-11-23 06:14:27 +00:00
|
|
|
admin_addr = 0.0.0.0
|
|
|
|
admin_port = %d
|
|
|
|
admin_user = admin
|
|
|
|
admin_pwd = admin
|
|
|
|
`, dashboardPort)
|
|
|
|
|
|
|
|
f.RunProcesses([]string{serverConf}, []string{clientConf})
|
|
|
|
|
|
|
|
framework.NewRequestExpect(f).RequestModify(func(r *request.Request) {
|
|
|
|
r.HTTP().HTTPPath("/healthz")
|
|
|
|
}).Port(dashboardPort).ExpectResp([]byte("")).Ensure()
|
|
|
|
|
|
|
|
framework.NewRequestExpect(f).RequestModify(func(r *request.Request) {
|
|
|
|
r.HTTP().HTTPPath("/")
|
|
|
|
}).Port(dashboardPort).
|
|
|
|
Ensure(framework.ExpectResponseCode(401))
|
|
|
|
})
|
2023-06-30 09:35:37 +00:00
|
|
|
|
|
|
|
ginkgo.It("stop", func() {
|
2023-09-13 08:32:39 +00:00
|
|
|
serverConf := consts.LegacyDefaultServerConfig
|
2023-06-30 09:35:37 +00:00
|
|
|
|
|
|
|
adminPort := f.AllocPort()
|
|
|
|
testPort := f.AllocPort()
|
2023-09-13 08:32:39 +00:00
|
|
|
clientConf := consts.LegacyDefaultClientConfig + fmt.Sprintf(`
|
2023-06-30 09:35:37 +00:00
|
|
|
admin_port = %d
|
|
|
|
|
|
|
|
[test]
|
|
|
|
type = tcp
|
|
|
|
local_port = {{ .%s }}
|
|
|
|
remote_port = %d
|
|
|
|
`, adminPort, framework.TCPEchoServerPort, testPort)
|
|
|
|
|
|
|
|
f.RunProcesses([]string{serverConf}, []string{clientConf})
|
|
|
|
|
|
|
|
framework.NewRequestExpect(f).Port(testPort).Ensure()
|
|
|
|
|
|
|
|
client := clientsdk.New("127.0.0.1", adminPort)
|
|
|
|
err := client.Stop()
|
|
|
|
framework.ExpectNoError(err)
|
|
|
|
|
|
|
|
time.Sleep(3 * time.Second)
|
|
|
|
|
|
|
|
// frpc stopped so the port is not listened, expect error
|
|
|
|
framework.NewRequestExpect(f).Port(testPort).ExpectError(true).Ensure()
|
|
|
|
})
|
2021-06-18 08:48:36 +00:00
|
|
|
})
|