1
0

process.go 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  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. for _, t := range serverTemplates {
  15. templates = append(templates, t)
  16. }
  17. for _, t := range clientTemplates {
  18. templates = append(templates, t)
  19. }
  20. outs, ports, err := f.RenderTemplates(templates)
  21. ExpectNoError(err)
  22. ExpectTrue(len(templates) > 0)
  23. for name, port := range ports {
  24. f.usedPorts[name] = port
  25. }
  26. currentServerProcesses := make([]*process.Process, 0, len(serverTemplates))
  27. for i := range serverTemplates {
  28. path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-server-%d", i))
  29. err = os.WriteFile(path, []byte(outs[i]), 0666)
  30. ExpectNoError(err)
  31. flog.Trace("[%s] %s", path, outs[i])
  32. p := process.NewWithEnvs(TestContext.FRPServerPath, []string{"-c", path}, f.osEnvs)
  33. f.serverConfPaths = append(f.serverConfPaths, path)
  34. f.serverProcesses = append(f.serverProcesses, p)
  35. currentServerProcesses = append(currentServerProcesses, p)
  36. err = p.Start()
  37. ExpectNoError(err)
  38. }
  39. time.Sleep(time.Second)
  40. currentClientProcesses := make([]*process.Process, 0, len(clientTemplates))
  41. for i := range clientTemplates {
  42. index := i + len(serverTemplates)
  43. path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-client-%d", i))
  44. err = os.WriteFile(path, []byte(outs[index]), 0666)
  45. ExpectNoError(err)
  46. flog.Trace("[%s] %s", path, outs[index])
  47. p := process.NewWithEnvs(TestContext.FRPClientPath, []string{"-c", path}, f.osEnvs)
  48. f.clientConfPaths = append(f.clientConfPaths, path)
  49. f.clientProcesses = append(f.clientProcesses, p)
  50. currentClientProcesses = append(currentClientProcesses, p)
  51. err = p.Start()
  52. ExpectNoError(err)
  53. time.Sleep(500 * time.Millisecond)
  54. }
  55. time.Sleep(time.Second)
  56. return currentServerProcesses, currentClientProcesses
  57. }
  58. func (f *Framework) RunFrps(args ...string) (*process.Process, string, error) {
  59. p := process.NewWithEnvs(TestContext.FRPServerPath, args, f.osEnvs)
  60. f.serverProcesses = append(f.serverProcesses, p)
  61. err := p.Start()
  62. if err != nil {
  63. return p, p.StdOutput(), err
  64. }
  65. // sleep for a while to get std output
  66. time.Sleep(500 * time.Millisecond)
  67. return p, p.StdOutput(), nil
  68. }
  69. func (f *Framework) RunFrpc(args ...string) (*process.Process, string, error) {
  70. p := process.NewWithEnvs(TestContext.FRPClientPath, args, f.osEnvs)
  71. f.clientProcesses = append(f.clientProcesses, p)
  72. err := p.Start()
  73. if err != nil {
  74. return p, p.StdOutput(), err
  75. }
  76. time.Sleep(500 * time.Millisecond)
  77. return p, p.StdOutput(), nil
  78. }
  79. func (f *Framework) GenerateConfigFile(content string) string {
  80. f.configFileIndex++
  81. path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-config-%d", f.configFileIndex))
  82. err := os.WriteFile(path, []byte(content), 0666)
  83. ExpectNoError(err)
  84. return path
  85. }