123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- package framework
- import (
- "fmt"
- "os"
- "path/filepath"
- "time"
- flog "github.com/fatedier/frp/pkg/util/log"
- "github.com/fatedier/frp/test/e2e/pkg/process"
- )
- // RunProcesses run multiple processes from templates.
- // The first template should always be frps.
- func (f *Framework) RunProcesses(serverTemplates []string, clientTemplates []string) ([]*process.Process, []*process.Process) {
- templates := make([]string, 0, len(serverTemplates)+len(clientTemplates))
- templates = append(templates, serverTemplates...)
- templates = append(templates, clientTemplates...)
- outs, ports, err := f.RenderTemplates(templates)
- ExpectNoError(err)
- ExpectTrue(len(templates) > 0)
- for name, port := range ports {
- f.usedPorts[name] = port
- }
- currentServerProcesses := make([]*process.Process, 0, len(serverTemplates))
- for i := range serverTemplates {
- path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-server-%d", i))
- err = os.WriteFile(path, []byte(outs[i]), 0o600)
- ExpectNoError(err)
- if TestContext.Debug {
- flog.Debugf("[%s] %s", path, outs[i])
- }
- p := process.NewWithEnvs(TestContext.FRPServerPath, []string{"-c", path}, f.osEnvs)
- f.serverConfPaths = append(f.serverConfPaths, path)
- f.serverProcesses = append(f.serverProcesses, p)
- currentServerProcesses = append(currentServerProcesses, p)
- err = p.Start()
- ExpectNoError(err)
- time.Sleep(500 * time.Millisecond)
- }
- time.Sleep(2 * time.Second)
- currentClientProcesses := make([]*process.Process, 0, len(clientTemplates))
- for i := range clientTemplates {
- index := i + len(serverTemplates)
- path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-client-%d", i))
- err = os.WriteFile(path, []byte(outs[index]), 0o600)
- ExpectNoError(err)
- if TestContext.Debug {
- flog.Debugf("[%s] %s", path, outs[index])
- }
- p := process.NewWithEnvs(TestContext.FRPClientPath, []string{"-c", path}, f.osEnvs)
- f.clientConfPaths = append(f.clientConfPaths, path)
- f.clientProcesses = append(f.clientProcesses, p)
- currentClientProcesses = append(currentClientProcesses, p)
- err = p.Start()
- ExpectNoError(err)
- time.Sleep(500 * time.Millisecond)
- }
- time.Sleep(3 * time.Second)
- return currentServerProcesses, currentClientProcesses
- }
- func (f *Framework) RunFrps(args ...string) (*process.Process, string, error) {
- p := process.NewWithEnvs(TestContext.FRPServerPath, args, f.osEnvs)
- f.serverProcesses = append(f.serverProcesses, p)
- err := p.Start()
- if err != nil {
- return p, p.StdOutput(), err
- }
- // sleep for a while to get std output
- time.Sleep(2 * time.Second)
- return p, p.StdOutput(), nil
- }
- func (f *Framework) RunFrpc(args ...string) (*process.Process, string, error) {
- p := process.NewWithEnvs(TestContext.FRPClientPath, args, f.osEnvs)
- f.clientProcesses = append(f.clientProcesses, p)
- err := p.Start()
- if err != nil {
- return p, p.StdOutput(), err
- }
- time.Sleep(2 * time.Second)
- return p, p.StdOutput(), nil
- }
- func (f *Framework) GenerateConfigFile(content string) string {
- f.configFileIndex++
- path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-config-%d", f.configFileIndex))
- err := os.WriteFile(path, []byte(content), 0o600)
- ExpectNoError(err)
- return path
- }
|