123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- package basic
- import (
- "fmt"
- "strconv"
- "strings"
- "time"
- "github.com/onsi/ginkgo/v2"
- "github.com/fatedier/frp/test/e2e/framework"
- "github.com/fatedier/frp/test/e2e/framework/consts"
- "github.com/fatedier/frp/test/e2e/pkg/request"
- )
- var _ = ginkgo.Describe("[Feature: ClientManage]", func() {
- f := framework.NewDefaultFramework()
- ginkgo.It("Update && Reload API", func() {
- serverConf := consts.LegacyDefaultServerConfig
- adminPort := f.AllocPort()
- p1Port := f.AllocPort()
- p2Port := f.AllocPort()
- p3Port := f.AllocPort()
- clientConf := consts.LegacyDefaultClientConfig + fmt.Sprintf(`
- 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 := f.APIClientForFrpc(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]")
- if p3Index >= 0 {
- newClientConf = newClientConf[:p3Index]
- }
- err = client.UpdateConfig(newClientConf)
- framework.ExpectNoError(err)
- err = client.Reload(true)
- 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()
- })
- ginkgo.It("healthz", func() {
- serverConf := consts.LegacyDefaultServerConfig
- dashboardPort := f.AllocPort()
- clientConf := consts.LegacyDefaultClientConfig + fmt.Sprintf(`
- 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))
- })
- ginkgo.It("stop", func() {
- serverConf := consts.LegacyDefaultServerConfig
- adminPort := f.AllocPort()
- testPort := f.AllocPort()
- clientConf := consts.LegacyDefaultClientConfig + fmt.Sprintf(`
- 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 := f.APIClientForFrpc(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()
- })
- })
|