1
0

process.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. package framework
  2. import (
  3. "fmt"
  4. "os"
  5. "path/filepath"
  6. "time"
  7. flog "github.com/fatedier/frp/pkg/util/log"
  8. "github.com/fatedier/frp/test/e2e/pkg/process"
  9. )
  10. // RunProcesses run multiple processes from templates.
  11. // The first template should always be frps.
  12. func (f *Framework) RunProcesses(serverTemplates []string, clientTemplates []string) ([]*process.Process, []*process.Process) {
  13. templates := make([]string, 0, len(serverTemplates)+len(clientTemplates))
  14. templates = append(templates, serverTemplates...)
  15. templates = append(templates, clientTemplates...)
  16. outs, ports, err := f.RenderTemplates(templates)
  17. ExpectNoError(err)
  18. ExpectTrue(len(templates) > 0)
  19. for name, port := range ports {
  20. f.usedPorts[name] = port
  21. }
  22. currentServerProcesses := make([]*process.Process, 0, len(serverTemplates))
  23. for i := range serverTemplates {
  24. path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-server-%d", i))
  25. err = os.WriteFile(path, []byte(outs[i]), 0o666)
  26. ExpectNoError(err)
  27. flog.Trace("[%s] %s", path, outs[i])
  28. p := process.NewWithEnvs(TestContext.FRPServerPath, []string{"-c", path}, f.osEnvs)
  29. f.serverConfPaths = append(f.serverConfPaths, path)
  30. f.serverProcesses = append(f.serverProcesses, p)
  31. currentServerProcesses = append(currentServerProcesses, p)
  32. err = p.Start()
  33. ExpectNoError(err)
  34. }
  35. time.Sleep(1 * time.Second)
  36. currentClientProcesses := make([]*process.Process, 0, len(clientTemplates))
  37. for i := range clientTemplates {
  38. index := i + len(serverTemplates)
  39. path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-client-%d", i))
  40. err = os.WriteFile(path, []byte(outs[index]), 0o666)
  41. ExpectNoError(err)
  42. flog.Trace("[%s] %s", path, outs[index])
  43. p := process.NewWithEnvs(TestContext.FRPClientPath, []string{"-c", path}, f.osEnvs)
  44. f.clientConfPaths = append(f.clientConfPaths, path)
  45. f.clientProcesses = append(f.clientProcesses, p)
  46. currentClientProcesses = append(currentClientProcesses, p)
  47. err = p.Start()
  48. ExpectNoError(err)
  49. time.Sleep(500 * time.Millisecond)
  50. }
  51. time.Sleep(3 * time.Second)
  52. return currentServerProcesses, currentClientProcesses
  53. }
  54. func (f *Framework) RunFrps(args ...string) (*process.Process, string, error) {
  55. p := process.NewWithEnvs(TestContext.FRPServerPath, args, f.osEnvs)
  56. f.serverProcesses = append(f.serverProcesses, p)
  57. err := p.Start()
  58. if err != nil {
  59. return p, p.StdOutput(), err
  60. }
  61. // sleep for a while to get std output
  62. time.Sleep(time.Second)
  63. return p, p.StdOutput(), nil
  64. }
  65. func (f *Framework) RunFrpc(args ...string) (*process.Process, string, error) {
  66. p := process.NewWithEnvs(TestContext.FRPClientPath, args, f.osEnvs)
  67. f.clientProcesses = append(f.clientProcesses, p)
  68. err := p.Start()
  69. if err != nil {
  70. return p, p.StdOutput(), err
  71. }
  72. time.Sleep(time.Second)
  73. return p, p.StdOutput(), nil
  74. }
  75. func (f *Framework) GenerateConfigFile(content string) string {
  76. f.configFileIndex++
  77. path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-config-%d", f.configFileIndex))
  78. err := os.WriteFile(path, []byte(content), 0o666)
  79. ExpectNoError(err)
  80. return path
  81. }