common.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. package scenarios
  2. import (
  3. "errors"
  4. "fmt"
  5. "io"
  6. "io/ioutil"
  7. "os"
  8. "os/exec"
  9. "path/filepath"
  10. "runtime"
  11. "sync"
  12. "time"
  13. "github.com/golang/protobuf/proto"
  14. "v2ray.com/core"
  15. "v2ray.com/core/app/log"
  16. "v2ray.com/core/common"
  17. "v2ray.com/core/common/net"
  18. "v2ray.com/core/common/retry"
  19. )
  20. func pickPort() net.Port {
  21. listener, err := net.Listen("tcp4", ":0")
  22. common.Must(err)
  23. defer listener.Close()
  24. addr := listener.Addr().(*net.TCPAddr)
  25. return net.Port(addr.Port)
  26. }
  27. func pickUDPPort() net.Port {
  28. conn, err := net.ListenUDP("udp4", &net.UDPAddr{
  29. IP: net.LocalHostIP.IP(),
  30. Port: 0,
  31. })
  32. common.Must(err)
  33. defer conn.Close()
  34. addr := conn.LocalAddr().(*net.UDPAddr)
  35. return net.Port(addr.Port)
  36. }
  37. func xor(b []byte) []byte {
  38. r := make([]byte, len(b))
  39. for i, v := range b {
  40. r[i] = v ^ 'c'
  41. }
  42. return r
  43. }
  44. func readFrom(conn net.Conn, timeout time.Duration, length int) []byte {
  45. b := make([]byte, length)
  46. deadline := time.Now().Add(timeout)
  47. conn.SetReadDeadline(deadline)
  48. n, err := io.ReadFull(conn, b[:length])
  49. if err != nil {
  50. fmt.Println("Unexpected error from readFrom:", err)
  51. }
  52. return b[:n]
  53. }
  54. func InitializeServerConfigs(configs ...*core.Config) ([]*exec.Cmd, error) {
  55. servers := make([]*exec.Cmd, 0, 10)
  56. for _, config := range configs {
  57. server, err := InitializeServerConfig(config)
  58. if err != nil {
  59. CloseAllServers(servers)
  60. return nil, err
  61. }
  62. servers = append(servers, server)
  63. }
  64. time.Sleep(time.Second * 2)
  65. return servers, nil
  66. }
  67. func InitializeServerConfig(config *core.Config) (*exec.Cmd, error) {
  68. err := BuildV2Ray()
  69. if err != nil {
  70. return nil, err
  71. }
  72. configBytes, err := proto.Marshal(config)
  73. if err != nil {
  74. return nil, err
  75. }
  76. proc := RunV2RayProtobuf(configBytes)
  77. if err := proc.Start(); err != nil {
  78. return nil, err
  79. }
  80. return proc, nil
  81. }
  82. var (
  83. testBinaryPath string
  84. testBinaryPathGen sync.Once
  85. )
  86. func genTestBinaryPath() {
  87. testBinaryPathGen.Do(func() {
  88. var tempDir string
  89. common.Must(retry.Timed(5, 100).On(func() error {
  90. dir, err := ioutil.TempDir("", "v2ray")
  91. if err != nil {
  92. return err
  93. }
  94. tempDir = dir
  95. return nil
  96. }))
  97. file := filepath.Join(tempDir, "v2ray.test")
  98. if runtime.GOOS == "windows" {
  99. file += ".exe"
  100. }
  101. testBinaryPath = file
  102. fmt.Printf("Generated binary path: %s\n", file)
  103. })
  104. }
  105. func GetSourcePath() string {
  106. return filepath.Join("v2ray.com", "core", "main")
  107. }
  108. func CloseAllServers(servers []*exec.Cmd) {
  109. log.Trace(errors.New("Closing all servers."))
  110. for _, server := range servers {
  111. server.Process.Signal(os.Interrupt)
  112. }
  113. for _, server := range servers {
  114. server.Process.Wait()
  115. }
  116. log.Trace(errors.New("All server closed."))
  117. }