mirror of
				https://github.com/fatedier/frp
				synced 2025-10-20 10:03:07 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			180 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			180 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package basic
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| 	"net"
 | |
| 	"strconv"
 | |
| 
 | |
| 	"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/port"
 | |
| 	"github.com/fatedier/frp/test/e2e/pkg/request"
 | |
| )
 | |
| 
 | |
| var _ = ginkgo.Describe("[Feature: Server Manager]", func() {
 | |
| 	f := framework.NewDefaultFramework()
 | |
| 
 | |
| 	ginkgo.It("Ports Whitelist", func() {
 | |
| 		serverConf := consts.LegacyDefaultServerConfig
 | |
| 		clientConf := consts.LegacyDefaultClientConfig
 | |
| 
 | |
| 		serverConf += `
 | |
| 			allow_ports = 10000-11000,11002,12000-13000
 | |
| 		`
 | |
| 
 | |
| 		tcpPortName := port.GenName("TCP", port.WithRangePorts(10000, 11000))
 | |
| 		udpPortName := port.GenName("UDP", port.WithRangePorts(12000, 13000))
 | |
| 		clientConf += fmt.Sprintf(`
 | |
| 			[tcp-allowded-in-range]
 | |
| 			type = tcp
 | |
| 			local_port = {{ .%s }}
 | |
| 			remote_port = {{ .%s }}
 | |
| 			`, framework.TCPEchoServerPort, tcpPortName)
 | |
| 		clientConf += fmt.Sprintf(`
 | |
| 			[tcp-port-not-allowed]
 | |
| 			type = tcp
 | |
| 			local_port = {{ .%s }}
 | |
| 			remote_port = 11001
 | |
| 			`, framework.TCPEchoServerPort)
 | |
| 		clientConf += fmt.Sprintf(`
 | |
| 			[tcp-port-unavailable]
 | |
| 			type = tcp
 | |
| 			local_port = {{ .%s }}
 | |
| 			remote_port = {{ .%s }}
 | |
| 			`, framework.TCPEchoServerPort, consts.PortServerName)
 | |
| 		clientConf += fmt.Sprintf(`
 | |
| 			[udp-allowed-in-range]
 | |
| 			type = udp
 | |
| 			local_port = {{ .%s }}
 | |
| 			remote_port = {{ .%s }}
 | |
| 			`, framework.UDPEchoServerPort, udpPortName)
 | |
| 		clientConf += fmt.Sprintf(`
 | |
| 			[udp-port-not-allowed]
 | |
| 			type = udp
 | |
| 			local_port = {{ .%s }}
 | |
| 			remote_port = 11003
 | |
| 			`, framework.UDPEchoServerPort)
 | |
| 
 | |
| 		f.RunProcesses([]string{serverConf}, []string{clientConf})
 | |
| 
 | |
| 		// TCP
 | |
| 		// Allowed in range
 | |
| 		framework.NewRequestExpect(f).PortName(tcpPortName).Ensure()
 | |
| 
 | |
| 		// Not Allowed
 | |
| 		framework.NewRequestExpect(f).Port(11001).ExpectError(true).Ensure()
 | |
| 
 | |
| 		// Unavailable, already bind by frps
 | |
| 		framework.NewRequestExpect(f).PortName(consts.PortServerName).ExpectError(true).Ensure()
 | |
| 
 | |
| 		// UDP
 | |
| 		// Allowed in range
 | |
| 		framework.NewRequestExpect(f).Protocol("udp").PortName(udpPortName).Ensure()
 | |
| 
 | |
| 		// Not Allowed
 | |
| 		framework.NewRequestExpect(f).RequestModify(func(r *request.Request) {
 | |
| 			r.UDP().Port(11003)
 | |
| 		}).ExpectError(true).Ensure()
 | |
| 	})
 | |
| 
 | |
| 	ginkgo.It("Alloc Random Port", func() {
 | |
| 		serverConf := consts.LegacyDefaultServerConfig
 | |
| 		clientConf := consts.LegacyDefaultClientConfig
 | |
| 
 | |
| 		adminPort := f.AllocPort()
 | |
| 		clientConf += fmt.Sprintf(`
 | |
| 		admin_port = %d
 | |
| 
 | |
| 		[tcp]
 | |
| 		type = tcp
 | |
| 		local_port = {{ .%s }}
 | |
| 
 | |
| 		[udp]
 | |
| 		type = udp
 | |
| 		local_port = {{ .%s }}
 | |
| 		`, adminPort, framework.TCPEchoServerPort, framework.UDPEchoServerPort)
 | |
| 
 | |
| 		f.RunProcesses([]string{serverConf}, []string{clientConf})
 | |
| 
 | |
| 		client := f.APIClientForFrpc(adminPort)
 | |
| 
 | |
| 		// tcp random port
 | |
| 		status, err := client.GetProxyStatus(context.Background(), "tcp")
 | |
| 		framework.ExpectNoError(err)
 | |
| 
 | |
| 		_, portStr, err := net.SplitHostPort(status.RemoteAddr)
 | |
| 		framework.ExpectNoError(err)
 | |
| 		port, err := strconv.Atoi(portStr)
 | |
| 		framework.ExpectNoError(err)
 | |
| 
 | |
| 		framework.NewRequestExpect(f).Port(port).Ensure()
 | |
| 
 | |
| 		// udp random port
 | |
| 		status, err = client.GetProxyStatus(context.Background(), "udp")
 | |
| 		framework.ExpectNoError(err)
 | |
| 
 | |
| 		_, portStr, err = net.SplitHostPort(status.RemoteAddr)
 | |
| 		framework.ExpectNoError(err)
 | |
| 		port, err = strconv.Atoi(portStr)
 | |
| 		framework.ExpectNoError(err)
 | |
| 
 | |
| 		framework.NewRequestExpect(f).Protocol("udp").Port(port).Ensure()
 | |
| 	})
 | |
| 
 | |
| 	ginkgo.It("Port Reuse", func() {
 | |
| 		serverConf := consts.LegacyDefaultServerConfig
 | |
| 		// Use same port as PortServer
 | |
| 		serverConf += fmt.Sprintf(`
 | |
| 		vhost_http_port = {{ .%s }}
 | |
| 		`, consts.PortServerName)
 | |
| 
 | |
| 		clientConf := consts.LegacyDefaultClientConfig + fmt.Sprintf(`
 | |
| 		[http]
 | |
| 		type = http
 | |
| 		local_port = {{ .%s }}
 | |
| 		custom_domains = example.com
 | |
| 		`, framework.HTTPSimpleServerPort)
 | |
| 
 | |
| 		f.RunProcesses([]string{serverConf}, []string{clientConf})
 | |
| 
 | |
| 		framework.NewRequestExpect(f).RequestModify(func(r *request.Request) {
 | |
| 			r.HTTP().HTTPHost("example.com")
 | |
| 		}).PortName(consts.PortServerName).Ensure()
 | |
| 	})
 | |
| 
 | |
| 	ginkgo.It("healthz", func() {
 | |
| 		serverConf := consts.LegacyDefaultServerConfig
 | |
| 		dashboardPort := f.AllocPort()
 | |
| 
 | |
| 		// Use same port as PortServer
 | |
| 		serverConf += fmt.Sprintf(`
 | |
| 		vhost_http_port = {{ .%s }}
 | |
| 		dashboard_addr = 0.0.0.0
 | |
| 		dashboard_port = %d
 | |
| 		dashboard_user = admin
 | |
| 		dashboard_pwd = admin
 | |
| 		`, consts.PortServerName, dashboardPort)
 | |
| 
 | |
| 		clientConf := consts.LegacyDefaultClientConfig + fmt.Sprintf(`
 | |
| 		[http]
 | |
| 		type = http
 | |
| 		local_port = {{ .%s }}
 | |
| 		custom_domains = example.com
 | |
| 		`, framework.HTTPSimpleServerPort)
 | |
| 
 | |
| 		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))
 | |
| 	})
 | |
| })
 | 
