2021-06-20 15:57:41 +00:00
|
|
|
package features
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
2022-08-28 17:02:53 +00:00
|
|
|
"github.com/onsi/ginkgo"
|
|
|
|
|
2021-06-20 15:57:41 +00:00
|
|
|
"github.com/fatedier/frp/test/e2e/framework"
|
|
|
|
"github.com/fatedier/frp/test/e2e/framework/consts"
|
|
|
|
"github.com/fatedier/frp/test/e2e/mock/server/streamserver"
|
|
|
|
"github.com/fatedier/frp/test/e2e/pkg/request"
|
|
|
|
)
|
|
|
|
|
2022-08-28 17:02:53 +00:00
|
|
|
var _ = ginkgo.Describe("[Feature: Bandwidth Limit]", func() {
|
2021-06-20 15:57:41 +00:00
|
|
|
f := framework.NewDefaultFramework()
|
|
|
|
|
2022-08-28 17:02:53 +00:00
|
|
|
ginkgo.It("Proxy Bandwidth Limit", func() {
|
2021-06-20 15:57:41 +00:00
|
|
|
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(`
|
|
|
|
[tcp]
|
|
|
|
type = tcp
|
|
|
|
local_port = %d
|
|
|
|
remote_port = %d
|
|
|
|
bandwidth_limit = 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()
|
2022-08-28 17:02:53 +00:00
|
|
|
duration := time.Since(start)
|
2021-06-20 15:57:41 +00:00
|
|
|
|
|
|
|
framework.ExpectTrue(duration.Seconds() > 7, "100Kb with 10KB limit, want > 7 seconds, but got %d seconds", duration.Seconds())
|
|
|
|
})
|
|
|
|
})
|