process.go 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. package framework
  2. import (
  3. "fmt"
  4. "io/ioutil"
  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. func GenerateConfigFile(path string, content string) error {
  11. return ioutil.WriteFile(path, []byte(content), 0666)
  12. }
  13. // RunProcesses run multiple processes from templates.
  14. // The first template should always be frps.
  15. func (f *Framework) RunProcesses(serverTemplates []string, clientTemplates []string) {
  16. templates := make([]string, 0, len(serverTemplates)+len(clientTemplates))
  17. for _, t := range serverTemplates {
  18. templates = append(templates, t)
  19. }
  20. for _, t := range clientTemplates {
  21. templates = append(templates, t)
  22. }
  23. outs, ports, err := f.RenderTemplates(templates)
  24. ExpectNoError(err)
  25. ExpectTrue(len(templates) > 0)
  26. for name, port := range ports {
  27. f.usedPorts[name] = port
  28. }
  29. for i := range serverTemplates {
  30. path := filepath.Join(f.TempDirectory, fmt.Sprintf("frp-e2e-server-%d", i))
  31. err = ioutil.WriteFile(path, []byte(outs[i]), 0666)
  32. ExpectNoError(err)
  33. flog.Trace("[%s] %s", path, outs[i])
  34. p := process.New(TestContext.FRPServerPath, []string{"-c", path})
  35. f.serverConfPaths = append(f.serverConfPaths, path)
  36. f.serverProcesses = append(f.serverProcesses, p)
  37. err = p.Start()
  38. ExpectNoError(err)
  39. }
  40. time.Sleep(time.Second)
  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 = ioutil.WriteFile(path, []byte(outs[index]), 0666)
  45. ExpectNoError(err)
  46. flog.Trace("[%s] %s", path, outs[index])
  47. p := process.New(TestContext.FRPClientPath, []string{"-c", path})
  48. f.clientConfPaths = append(f.clientConfPaths, path)
  49. f.clientProcesses = append(f.clientProcesses, p)
  50. err = p.Start()
  51. ExpectNoError(err)
  52. time.Sleep(500 * time.Millisecond)
  53. }
  54. time.Sleep(500 * time.Millisecond)
  55. }