dns_test.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. package scenarios
  2. import (
  3. "fmt"
  4. "testing"
  5. "time"
  6. "github.com/xtls/xray-core/app/dns"
  7. "github.com/xtls/xray-core/app/proxyman"
  8. "github.com/xtls/xray-core/app/router"
  9. "github.com/xtls/xray-core/common"
  10. "github.com/xtls/xray-core/common/net"
  11. "github.com/xtls/xray-core/common/serial"
  12. "github.com/xtls/xray-core/core"
  13. "github.com/xtls/xray-core/proxy/blackhole"
  14. "github.com/xtls/xray-core/proxy/freedom"
  15. "github.com/xtls/xray-core/proxy/socks"
  16. "github.com/xtls/xray-core/testing/servers/tcp"
  17. "github.com/xtls/xray-core/transport/internet"
  18. xproxy "golang.org/x/net/proxy"
  19. )
  20. func TestResolveIP(t *testing.T) {
  21. tcpServer := tcp.Server{
  22. MsgProcessor: xor,
  23. }
  24. dest, err := tcpServer.Start()
  25. common.Must(err)
  26. defer tcpServer.Close()
  27. serverPort := tcp.PickPort()
  28. serverConfig := &core.Config{
  29. App: []*serial.TypedMessage{
  30. serial.ToTypedMessage(&dns.Config{
  31. StaticHosts: []*dns.Config_HostMapping{
  32. {
  33. Type: dns.DomainMatchingType_Full,
  34. Domain: "google.com",
  35. Ip: [][]byte{dest.Address.IP()},
  36. },
  37. },
  38. }),
  39. serial.ToTypedMessage(&router.Config{
  40. DomainStrategy: router.Config_IpIfNonMatch,
  41. Rule: []*router.RoutingRule{
  42. {
  43. Geoip: []*router.GeoIP{
  44. {
  45. Cidr: []*router.CIDR{
  46. {
  47. Ip: []byte{127, 0, 0, 0},
  48. Prefix: 8,
  49. },
  50. },
  51. },
  52. },
  53. TargetTag: &router.RoutingRule_Tag{
  54. Tag: "direct",
  55. },
  56. },
  57. },
  58. }),
  59. },
  60. Inbound: []*core.InboundHandlerConfig{
  61. {
  62. ReceiverSettings: serial.ToTypedMessage(&proxyman.ReceiverConfig{
  63. PortList: &net.PortList{Range: []*net.PortRange{net.SinglePortRange(serverPort)}},
  64. Listen: net.NewIPOrDomain(net.LocalHostIP),
  65. }),
  66. ProxySettings: serial.ToTypedMessage(&socks.ServerConfig{
  67. AuthType: socks.AuthType_NO_AUTH,
  68. Accounts: map[string]string{
  69. "Test Account": "Test Password",
  70. },
  71. Address: net.NewIPOrDomain(net.LocalHostIP),
  72. UdpEnabled: false,
  73. }),
  74. },
  75. },
  76. Outbound: []*core.OutboundHandlerConfig{
  77. {
  78. ProxySettings: serial.ToTypedMessage(&blackhole.Config{}),
  79. },
  80. {
  81. Tag: "direct",
  82. ProxySettings: serial.ToTypedMessage(&freedom.Config{
  83. DomainStrategy: internet.DomainStrategy_USE_IP,
  84. }),
  85. },
  86. },
  87. }
  88. servers, err := InitializeServerConfigs(serverConfig)
  89. common.Must(err)
  90. defer CloseAllServers(servers)
  91. {
  92. noAuthDialer, err := xproxy.SOCKS5("tcp", net.TCPDestination(net.LocalHostIP, serverPort).NetAddr(), nil, xproxy.Direct)
  93. common.Must(err)
  94. conn, err := noAuthDialer.Dial("tcp", fmt.Sprintf("google.com:%d", dest.Port))
  95. common.Must(err)
  96. defer conn.Close()
  97. if err := testTCPConn2(conn, 1024, time.Second*5)(); err != nil {
  98. t.Error(err)
  99. }
  100. }
  101. }