server_test.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. package dns_test
  2. import (
  3. "runtime"
  4. "testing"
  5. "time"
  6. "v2ray.com/core"
  7. "v2ray.com/core/app/dispatcher"
  8. . "v2ray.com/core/app/dns"
  9. "v2ray.com/core/app/policy"
  10. "v2ray.com/core/app/proxyman"
  11. _ "v2ray.com/core/app/proxyman/outbound"
  12. "v2ray.com/core/common/net"
  13. "v2ray.com/core/common/serial"
  14. feature_dns "v2ray.com/core/features/dns"
  15. "v2ray.com/core/proxy/freedom"
  16. "v2ray.com/core/testing/servers/udp"
  17. . "v2ray.com/ext/assert"
  18. "github.com/miekg/dns"
  19. )
  20. type staticHandler struct {
  21. }
  22. func (*staticHandler) ServeDNS(w dns.ResponseWriter, r *dns.Msg) {
  23. ans := new(dns.Msg)
  24. ans.Id = r.Id
  25. for _, q := range r.Question {
  26. if q.Name == "google.com." && q.Qtype == dns.TypeA {
  27. rr, _ := dns.NewRR("google.com. IN A 8.8.8.8")
  28. ans.Answer = append(ans.Answer, rr)
  29. } else if q.Name == "facebook.com." && q.Qtype == dns.TypeA {
  30. rr, _ := dns.NewRR("facebook.com. IN A 9.9.9.9")
  31. ans.Answer = append(ans.Answer, rr)
  32. }
  33. }
  34. w.WriteMsg(ans)
  35. }
  36. func TestUDPServer(t *testing.T) {
  37. if runtime.GOOS == "windows" {
  38. t.Skip("doesn't work on Windows due to miekg/dns changes.")
  39. }
  40. assert := With(t)
  41. port := udp.PickPort()
  42. dnsServer := dns.Server{
  43. Addr: "127.0.0.1:" + port.String(),
  44. Net: "udp",
  45. Handler: &staticHandler{},
  46. UDPSize: 1200,
  47. }
  48. go dnsServer.ListenAndServe()
  49. time.Sleep(time.Second)
  50. config := &core.Config{
  51. App: []*serial.TypedMessage{
  52. serial.ToTypedMessage(&Config{
  53. NameServers: []*net.Endpoint{
  54. {
  55. Network: net.Network_UDP,
  56. Address: &net.IPOrDomain{
  57. Address: &net.IPOrDomain_Ip{
  58. Ip: []byte{127, 0, 0, 1},
  59. },
  60. },
  61. Port: uint32(port),
  62. },
  63. },
  64. }),
  65. serial.ToTypedMessage(&dispatcher.Config{}),
  66. serial.ToTypedMessage(&proxyman.OutboundConfig{}),
  67. serial.ToTypedMessage(&policy.Config{}),
  68. },
  69. Outbound: []*core.OutboundHandlerConfig{
  70. {
  71. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  72. },
  73. },
  74. }
  75. v, err := core.New(config)
  76. assert(err, IsNil)
  77. client := v.GetFeature(feature_dns.ClientType()).(feature_dns.Client)
  78. ips, err := client.LookupIP("google.com")
  79. assert(err, IsNil)
  80. assert(len(ips), Equals, 1)
  81. assert([]byte(ips[0]), Equals, []byte{8, 8, 8, 8})
  82. ips, err = client.LookupIP("facebook.com")
  83. assert(err, IsNil)
  84. assert(len(ips), Equals, 1)
  85. assert([]byte(ips[0]), Equals, []byte{9, 9, 9, 9})
  86. dnsServer.Shutdown()
  87. ips, err = client.LookupIP("google.com")
  88. assert(err, IsNil)
  89. assert(len(ips), Equals, 1)
  90. assert([]byte(ips[0]), Equals, []byte{8, 8, 8, 8})
  91. }
  92. func TestPrioritizedDomain(t *testing.T) {
  93. if runtime.GOOS == "windows" {
  94. t.Skip("doesn't work on Windows due to miekg/dns changes.")
  95. }
  96. assert := With(t)
  97. port := udp.PickPort()
  98. dnsServer := dns.Server{
  99. Addr: "127.0.0.1:" + port.String(),
  100. Net: "udp",
  101. Handler: &staticHandler{},
  102. UDPSize: 1200,
  103. }
  104. go dnsServer.ListenAndServe()
  105. time.Sleep(time.Second)
  106. config := &core.Config{
  107. App: []*serial.TypedMessage{
  108. serial.ToTypedMessage(&Config{
  109. NameServers: []*net.Endpoint{
  110. {
  111. Network: net.Network_UDP,
  112. Address: &net.IPOrDomain{
  113. Address: &net.IPOrDomain_Ip{
  114. Ip: []byte{127, 0, 0, 1},
  115. },
  116. },
  117. Port: 9999, /* unreachable */
  118. },
  119. },
  120. NameServer: []*NameServer{
  121. {
  122. Address: &net.Endpoint{
  123. Network: net.Network_UDP,
  124. Address: &net.IPOrDomain{
  125. Address: &net.IPOrDomain_Ip{
  126. Ip: []byte{127, 0, 0, 1},
  127. },
  128. },
  129. Port: uint32(port),
  130. },
  131. PrioritizedDomain: []*NameServer_PriorityDomain{
  132. {
  133. Type: DomainMatchingType_Full,
  134. Domain: "google.com",
  135. },
  136. },
  137. },
  138. },
  139. }),
  140. serial.ToTypedMessage(&dispatcher.Config{}),
  141. serial.ToTypedMessage(&proxyman.OutboundConfig{}),
  142. serial.ToTypedMessage(&policy.Config{}),
  143. },
  144. Outbound: []*core.OutboundHandlerConfig{
  145. {
  146. ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
  147. },
  148. },
  149. }
  150. v, err := core.New(config)
  151. assert(err, IsNil)
  152. client := v.GetFeature(feature_dns.ClientType()).(feature_dns.Client)
  153. startTime := time.Now()
  154. ips, err := client.LookupIP("google.com")
  155. assert(err, IsNil)
  156. assert(len(ips), Equals, 1)
  157. assert([]byte(ips[0]), Equals, []byte{8, 8, 8, 8})
  158. endTime := time.Now()
  159. if startTime.After(endTime.Add(time.Second * 2)) {
  160. t.Error("DNS query doesn't finish in 2 seconds.")
  161. }
  162. }