123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- package features
- import (
- "fmt"
- "strings"
- "time"
- "github.com/onsi/ginkgo/v2"
- plugin "github.com/fatedier/frp/pkg/plugin/server"
- "github.com/fatedier/frp/test/e2e/framework"
- "github.com/fatedier/frp/test/e2e/framework/consts"
- "github.com/fatedier/frp/test/e2e/mock/server/streamserver"
- pluginpkg "github.com/fatedier/frp/test/e2e/pkg/plugin"
- "github.com/fatedier/frp/test/e2e/pkg/request"
- )
- var _ = ginkgo.Describe("[Feature: Bandwidth Limit]", func() {
- f := framework.NewDefaultFramework()
- ginkgo.It("Proxy Bandwidth Limit by Client", func() {
- serverConf := consts.DefaultServerConfig
- clientConf := consts.DefaultClientConfig
- localPort := f.AllocPort()
- localServer := streamserver.New(streamserver.TCP, streamserver.WithBindPort(localPort))
- f.RunServer("", localServer)
- remotePort := f.AllocPort()
- clientConf += fmt.Sprintf(`
- [[proxies]]
- name = "tcp"
- type = "tcp"
- localPort = %d
- remotePort = %d
- transport.bandwidthLimit = "10KB"
- `, localPort, remotePort)
- f.RunProcesses([]string{serverConf}, []string{clientConf})
- content := strings.Repeat("a", 50*1024) // 5KB
- start := time.Now()
- framework.NewRequestExpect(f).Port(remotePort).RequestModify(func(r *request.Request) {
- r.Body([]byte(content)).Timeout(30 * time.Second)
- }).ExpectResp([]byte(content)).Ensure()
- duration := time.Since(start)
- framework.Logf("request duration: %s", duration.String())
- framework.ExpectTrue(duration.Seconds() > 8, "100Kb with 10KB limit, want > 8 seconds, but got %s", duration.String())
- })
- ginkgo.It("Proxy Bandwidth Limit by Server", func() {
- // new test plugin server
- newFunc := func() *plugin.Request {
- var r plugin.Request
- r.Content = &plugin.NewProxyContent{}
- return &r
- }
- pluginPort := f.AllocPort()
- handler := func(req *plugin.Request) *plugin.Response {
- var ret plugin.Response
- content := req.Content.(*plugin.NewProxyContent)
- content.BandwidthLimit = "10KB"
- content.BandwidthLimitMode = "server"
- ret.Content = content
- return &ret
- }
- pluginServer := pluginpkg.NewHTTPPluginServer(pluginPort, newFunc, handler, nil)
- f.RunServer("", pluginServer)
- serverConf := consts.DefaultServerConfig + fmt.Sprintf(`
- [[httpPlugins]]
- name = "test"
- addr = "127.0.0.1:%d"
- path = "/handler"
- ops = ["NewProxy"]
- `, pluginPort)
- clientConf := consts.DefaultClientConfig
- localPort := f.AllocPort()
- localServer := streamserver.New(streamserver.TCP, streamserver.WithBindPort(localPort))
- f.RunServer("", localServer)
- remotePort := f.AllocPort()
- clientConf += fmt.Sprintf(`
- [[proxies]]
- name = "tcp"
- type = "tcp"
- localPort = %d
- remotePort = %d
- `, localPort, remotePort)
- f.RunProcesses([]string{serverConf}, []string{clientConf})
- content := strings.Repeat("a", 50*1024) // 5KB
- start := time.Now()
- framework.NewRequestExpect(f).Port(remotePort).RequestModify(func(r *request.Request) {
- r.Body([]byte(content)).Timeout(30 * time.Second)
- }).ExpectResp([]byte(content)).Ensure()
- duration := time.Since(start)
- framework.Logf("request duration: %s", duration.String())
- framework.ExpectTrue(duration.Seconds() > 8, "100Kb with 10KB limit, want > 8 seconds, but got %s", duration.String())
- })
- })
|