2013-08-13 10:44:12 -06:00
|
|
|
// Copyright 2013 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2014-04-30 08:26:07 -06:00
|
|
|
// +build darwin dragonfly freebsd linux netbsd openbsd solaris
|
2013-08-13 14:44:57 -06:00
|
|
|
|
2013-08-13 10:44:12 -06:00
|
|
|
package net
|
|
|
|
|
|
|
|
import (
|
2015-06-10 21:46:01 -06:00
|
|
|
"fmt"
|
2014-05-14 18:11:00 -06:00
|
|
|
"io/ioutil"
|
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"reflect"
|
2015-06-10 21:46:01 -06:00
|
|
|
"strings"
|
|
|
|
"sync"
|
2013-08-13 10:44:12 -06:00
|
|
|
"testing"
|
2014-05-14 18:11:00 -06:00
|
|
|
"time"
|
2013-08-13 10:44:12 -06:00
|
|
|
)
|
|
|
|
|
2014-08-05 18:58:47 -06:00
|
|
|
var dnsTransportFallbackTests = []struct {
|
|
|
|
server string
|
|
|
|
name string
|
|
|
|
qtype uint16
|
|
|
|
timeout int
|
|
|
|
rcode int
|
|
|
|
}{
|
|
|
|
// Querying "com." with qtype=255 usually makes an answer
|
|
|
|
// which requires more than 512 bytes.
|
|
|
|
{"8.8.8.8:53", "com.", dnsTypeALL, 2, dnsRcodeSuccess},
|
|
|
|
{"8.8.4.4:53", "com.", dnsTypeALL, 4, dnsRcodeSuccess},
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDNSTransportFallback(t *testing.T) {
|
2013-08-13 10:44:12 -06:00
|
|
|
if testing.Short() || !*testExternal {
|
2015-04-30 21:38:42 -06:00
|
|
|
t.Skip("avoid external network")
|
2013-08-13 10:44:12 -06:00
|
|
|
}
|
2014-08-05 18:58:47 -06:00
|
|
|
|
|
|
|
for _, tt := range dnsTransportFallbackTests {
|
|
|
|
timeout := time.Duration(tt.timeout) * time.Second
|
|
|
|
msg, err := exchange(tt.server, tt.name, tt.qtype, timeout)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
switch msg.rcode {
|
|
|
|
case tt.rcode, dnsRcodeServerFailure:
|
|
|
|
default:
|
|
|
|
t.Errorf("got %v from %v; want %v", msg.rcode, tt.server, tt.rcode)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// See RFC 6761 for further information about the reserved, pseudo
|
|
|
|
// domain names.
|
|
|
|
var specialDomainNameTests = []struct {
|
|
|
|
name string
|
|
|
|
qtype uint16
|
|
|
|
rcode int
|
|
|
|
}{
|
2015-01-14 22:25:26 -07:00
|
|
|
// Name resolution APIs and libraries should not recognize the
|
2014-08-05 18:58:47 -06:00
|
|
|
// followings as special.
|
|
|
|
{"1.0.168.192.in-addr.arpa.", dnsTypePTR, dnsRcodeNameError},
|
|
|
|
{"test.", dnsTypeALL, dnsRcodeNameError},
|
|
|
|
{"example.com.", dnsTypeALL, dnsRcodeSuccess},
|
|
|
|
|
2015-01-14 22:25:26 -07:00
|
|
|
// Name resolution APIs and libraries should recognize the
|
2014-08-05 18:58:47 -06:00
|
|
|
// followings as special and should not send any queries.
|
|
|
|
// Though, we test those names here for verifying nagative
|
|
|
|
// answers at DNS query-response interaction level.
|
|
|
|
{"localhost.", dnsTypeALL, dnsRcodeNameError},
|
|
|
|
{"invalid.", dnsTypeALL, dnsRcodeNameError},
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSpecialDomainName(t *testing.T) {
|
|
|
|
if testing.Short() || !*testExternal {
|
2015-04-30 21:38:42 -06:00
|
|
|
t.Skip("avoid external network")
|
2013-08-13 10:44:12 -06:00
|
|
|
}
|
2014-08-05 18:58:47 -06:00
|
|
|
|
|
|
|
server := "8.8.8.8:53"
|
|
|
|
for _, tt := range specialDomainNameTests {
|
|
|
|
msg, err := exchange(server, tt.name, tt.qtype, 0)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
switch msg.rcode {
|
|
|
|
case tt.rcode, dnsRcodeServerFailure:
|
|
|
|
default:
|
|
|
|
t.Errorf("got %v from %v; want %v", msg.rcode, server, tt.rcode)
|
|
|
|
continue
|
|
|
|
}
|
2013-08-13 10:44:12 -06:00
|
|
|
}
|
|
|
|
}
|
2014-05-14 18:11:00 -06:00
|
|
|
|
|
|
|
type resolvConfTest struct {
|
2015-05-12 21:56:56 -06:00
|
|
|
dir string
|
|
|
|
path string
|
2015-06-10 21:46:01 -06:00
|
|
|
*resolverConfig
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
func newResolvConfTest() (*resolvConfTest, error) {
|
2015-05-05 19:41:01 -06:00
|
|
|
dir, err := ioutil.TempDir("", "go-resolvconftest")
|
2014-05-14 18:11:00 -06:00
|
|
|
if err != nil {
|
2015-06-10 21:46:01 -06:00
|
|
|
return nil, err
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
2015-06-10 21:46:01 -06:00
|
|
|
conf := &resolvConfTest{
|
|
|
|
dir: dir,
|
|
|
|
path: path.Join(dir, "resolv.conf"),
|
|
|
|
resolverConfig: &resolvConf,
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
2015-06-10 21:46:01 -06:00
|
|
|
conf.initOnce.Do(conf.init)
|
|
|
|
return conf, nil
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
func (conf *resolvConfTest) writeAndUpdate(lines []string) error {
|
|
|
|
f, err := os.OpenFile(conf.path, os.O_CREATE|os.O_TRUNC|os.O_WRONLY, 0600)
|
2014-05-14 18:11:00 -06:00
|
|
|
if err != nil {
|
2015-06-10 21:46:01 -06:00
|
|
|
return err
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
2015-06-10 21:46:01 -06:00
|
|
|
if _, err := f.WriteString(strings.Join(lines, "\n")); err != nil {
|
2014-05-14 18:11:00 -06:00
|
|
|
f.Close()
|
2015-06-10 21:46:01 -06:00
|
|
|
return err
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
|
|
|
f.Close()
|
2015-06-10 21:46:01 -06:00
|
|
|
if err := conf.forceUpdate(conf.path); err != nil {
|
|
|
|
return err
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
2015-06-10 21:46:01 -06:00
|
|
|
return nil
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
func (conf *resolvConfTest) forceUpdate(name string) error {
|
|
|
|
dnsConf := dnsReadConfig(name)
|
|
|
|
conf.mu.Lock()
|
|
|
|
conf.dnsConfig = dnsConf
|
|
|
|
conf.mu.Unlock()
|
|
|
|
for i := 0; i < 5; i++ {
|
|
|
|
if conf.tryAcquireSema() {
|
|
|
|
conf.lastChecked = time.Time{}
|
|
|
|
conf.releaseSema()
|
|
|
|
return nil
|
|
|
|
}
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
2015-06-10 21:46:01 -06:00
|
|
|
return fmt.Errorf("tryAcquireSema for %s failed", name)
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
func (conf *resolvConfTest) servers() []string {
|
|
|
|
conf.mu.RLock()
|
|
|
|
servers := conf.dnsConfig.servers
|
|
|
|
conf.mu.RUnlock()
|
|
|
|
return servers
|
|
|
|
}
|
2015-04-25 18:50:21 -06:00
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
func (conf *resolvConfTest) teardown() error {
|
|
|
|
err := conf.forceUpdate("/etc/resolv.conf")
|
|
|
|
os.RemoveAll(conf.dir)
|
|
|
|
return err
|
|
|
|
}
|
2015-04-25 18:50:21 -06:00
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
var updateResolvConfTests = []struct {
|
|
|
|
name string // query name
|
|
|
|
lines []string // resolver configuration lines
|
|
|
|
servers []string // expected name servers
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "golang.org",
|
|
|
|
lines: []string{"nameserver 8.8.8.8"},
|
|
|
|
servers: []string{"8.8.8.8"},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "",
|
|
|
|
lines: nil, // an empty resolv.conf should use defaultNS as name servers
|
|
|
|
servers: defaultNS,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "www.example.com",
|
|
|
|
lines: []string{"nameserver 8.8.4.4"},
|
|
|
|
servers: []string{"8.8.4.4"},
|
|
|
|
},
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
func TestUpdateResolvConf(t *testing.T) {
|
2014-05-14 18:11:00 -06:00
|
|
|
if testing.Short() || !*testExternal {
|
2015-04-30 21:38:42 -06:00
|
|
|
t.Skip("avoid external network")
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
conf, err := newResolvConfTest()
|
|
|
|
if err != nil {
|
2015-04-30 21:38:42 -06:00
|
|
|
t.Fatal(err)
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
2015-06-10 21:46:01 -06:00
|
|
|
defer conf.teardown()
|
2014-05-14 18:11:00 -06:00
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
for i, tt := range updateResolvConfTests {
|
|
|
|
if err := conf.writeAndUpdate(tt.lines); err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if tt.name != "" {
|
|
|
|
var wg sync.WaitGroup
|
|
|
|
const N = 10
|
|
|
|
wg.Add(N)
|
|
|
|
for j := 0; j < N; j++ {
|
|
|
|
go func(name string) {
|
|
|
|
defer wg.Done()
|
|
|
|
ips, err := goLookupIP(name)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if len(ips) == 0 {
|
|
|
|
t.Errorf("no records for %s", name)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}(tt.name)
|
|
|
|
}
|
|
|
|
wg.Wait()
|
|
|
|
}
|
|
|
|
servers := conf.servers()
|
|
|
|
if !reflect.DeepEqual(servers, tt.servers) {
|
|
|
|
t.Errorf("#%d: got %v; want %v", i, servers, tt.servers)
|
|
|
|
continue
|
2015-04-25 18:50:21 -06:00
|
|
|
}
|
2014-05-14 18:11:00 -06:00
|
|
|
}
|
|
|
|
}
|
2014-08-29 16:50:50 -06:00
|
|
|
|
2015-06-09 02:30:00 -06:00
|
|
|
var goLookupIPWithResolverConfigTests = []struct {
|
|
|
|
name string
|
|
|
|
lines []string // resolver configuration lines
|
|
|
|
error
|
|
|
|
a, aaaa bool // whether response contains A, AAAA-record
|
|
|
|
}{
|
|
|
|
// no records, transport timeout
|
|
|
|
{
|
|
|
|
"jgahvsekduiv9bw4b3qhn4ykdfgj0493iohkrjfhdvhjiu4j",
|
|
|
|
[]string{
|
|
|
|
"options timeout:1 attempts:1",
|
|
|
|
"nameserver 255.255.255.255", // please forgive us for abuse of limited broadcast address
|
|
|
|
},
|
|
|
|
&DNSError{Name: "jgahvsekduiv9bw4b3qhn4ykdfgj0493iohkrjfhdvhjiu4j", Server: "255.255.255.255:53", IsTimeout: true},
|
|
|
|
false, false,
|
|
|
|
},
|
|
|
|
|
|
|
|
// no records, non-existent domain
|
|
|
|
{
|
|
|
|
"jgahvsekduiv9bw4b3qhn4ykdfgj0493iohkrjfhdvhjiu4j",
|
|
|
|
[]string{
|
|
|
|
"options timeout:3 attempts:1",
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
},
|
|
|
|
&DNSError{Name: "jgahvsekduiv9bw4b3qhn4ykdfgj0493iohkrjfhdvhjiu4j", Server: "8.8.8.8:53", IsTimeout: false},
|
|
|
|
false, false,
|
|
|
|
},
|
|
|
|
|
|
|
|
// a few A records, no AAAA records
|
|
|
|
{
|
|
|
|
"ipv4.google.com.",
|
|
|
|
[]string{
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
"nameserver 2001:4860:4860::8888",
|
|
|
|
},
|
|
|
|
nil,
|
|
|
|
true, false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"ipv4.google.com",
|
|
|
|
[]string{
|
|
|
|
"domain golang.org",
|
|
|
|
"nameserver 2001:4860:4860::8888",
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
},
|
|
|
|
nil,
|
|
|
|
true, false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"ipv4.google.com",
|
|
|
|
[]string{
|
|
|
|
"search x.golang.org y.golang.org",
|
|
|
|
"nameserver 2001:4860:4860::8888",
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
},
|
|
|
|
nil,
|
|
|
|
true, false,
|
|
|
|
},
|
|
|
|
|
|
|
|
// no A records, a few AAAA records
|
|
|
|
{
|
|
|
|
"ipv6.google.com.",
|
|
|
|
[]string{
|
|
|
|
"nameserver 2001:4860:4860::8888",
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
},
|
|
|
|
nil,
|
|
|
|
false, true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"ipv6.google.com",
|
|
|
|
[]string{
|
|
|
|
"domain golang.org",
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
"nameserver 2001:4860:4860::8888",
|
|
|
|
},
|
|
|
|
nil,
|
|
|
|
false, true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"ipv6.google.com",
|
|
|
|
[]string{
|
|
|
|
"search x.golang.org y.golang.org",
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
"nameserver 2001:4860:4860::8888",
|
|
|
|
},
|
|
|
|
nil,
|
|
|
|
false, true,
|
|
|
|
},
|
|
|
|
|
|
|
|
// both A and AAAA records
|
|
|
|
{
|
|
|
|
"hostname.as112.net", // see RFC 7534
|
|
|
|
[]string{
|
|
|
|
"domain golang.org",
|
|
|
|
"nameserver 2001:4860:4860::8888",
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
},
|
|
|
|
nil,
|
|
|
|
true, true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"hostname.as112.net", // see RFC 7534
|
|
|
|
[]string{
|
|
|
|
"search x.golang.org y.golang.org",
|
|
|
|
"nameserver 2001:4860:4860::8888",
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
},
|
|
|
|
nil,
|
|
|
|
true, true,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGoLookupIPWithResolverConfig(t *testing.T) {
|
|
|
|
if testing.Short() || !*testExternal {
|
|
|
|
t.Skip("avoid external network")
|
|
|
|
}
|
|
|
|
|
|
|
|
conf, err := newResolvConfTest()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
defer conf.teardown()
|
|
|
|
|
|
|
|
for _, tt := range goLookupIPWithResolverConfigTests {
|
|
|
|
if err := conf.writeAndUpdate(tt.lines); err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
conf.tryUpdate(conf.path)
|
|
|
|
addrs, err := goLookupIP(tt.name)
|
|
|
|
if err != nil {
|
|
|
|
if err, ok := err.(*DNSError); !ok || (err.Name != tt.error.(*DNSError).Name || err.Server != tt.error.(*DNSError).Server || err.IsTimeout != tt.error.(*DNSError).IsTimeout) {
|
|
|
|
t.Errorf("got %v; want %v", err, tt.error)
|
|
|
|
}
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if len(addrs) == 0 {
|
|
|
|
t.Errorf("no records for %s", tt.name)
|
|
|
|
}
|
|
|
|
if !tt.a && !tt.aaaa && len(addrs) > 0 {
|
|
|
|
t.Errorf("unexpected %v for %s", addrs, tt.name)
|
|
|
|
}
|
|
|
|
for _, addr := range addrs {
|
|
|
|
if !tt.a && addr.IP.To4() != nil {
|
|
|
|
t.Errorf("got %v; must not be IPv4 address", addr)
|
|
|
|
}
|
|
|
|
if !tt.aaaa && addr.IP.To16() != nil && addr.IP.To4() == nil {
|
|
|
|
t.Errorf("got %v; must not be IPv6 address", addr)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-11-29 22:08:46 -07:00
|
|
|
// Test that goLookupIPOrder falls back to the host file when no DNS servers are available.
|
|
|
|
func TestGoLookupIPOrderFallbackToFile(t *testing.T) {
|
|
|
|
if testing.Short() || !*testExternal {
|
|
|
|
t.Skip("avoid external network")
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add a config that simulates no dns servers being available.
|
|
|
|
conf, err := newResolvConfTest()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
if err := conf.writeAndUpdate([]string{}); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
conf.tryUpdate(conf.path)
|
|
|
|
// Redirect host file lookups.
|
|
|
|
defer func(orig string) { testHookHostsPath = orig }(testHookHostsPath)
|
|
|
|
testHookHostsPath = "testdata/hosts"
|
|
|
|
|
|
|
|
for _, order := range []hostLookupOrder{hostLookupFilesDNS, hostLookupDNSFiles} {
|
|
|
|
name := fmt.Sprintf("order %v", order)
|
|
|
|
|
|
|
|
// First ensure that we get an error when contacting a non-existant host.
|
|
|
|
_, err := goLookupIPOrder("notarealhost", order)
|
|
|
|
if err == nil {
|
|
|
|
t.Errorf("%s: expected error while looking up name not in hosts file", name)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
// Now check that we get an address when the name appears in the hosts file.
|
|
|
|
addrs, err := goLookupIPOrder("thor", order) // entry is in "testdata/hosts"
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("%s: expected to successfully lookup host entry", name)
|
|
|
|
continue
|
|
|
|
}
|
2015-12-01 20:02:04 -07:00
|
|
|
if len(addrs) != 1 {
|
|
|
|
t.Errorf("%s: expected exactly one result, but got %v", name, addrs)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if got, want := addrs[0].String(), "127.1.1.1"; got != want {
|
2015-11-29 22:08:46 -07:00
|
|
|
t.Errorf("%s: address doesn't match expectation. got %v, want %v", name, got, want)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
defer conf.teardown()
|
|
|
|
}
|
|
|
|
|
2014-08-29 22:12:28 -06:00
|
|
|
func BenchmarkGoLookupIP(b *testing.B) {
|
2015-05-13 18:25:24 -06:00
|
|
|
testHookUninstaller.Do(uninstallTestHooks)
|
net: add socket system call hooks for testing
This change adds socket system call hooks to existing test cases for
simulating a bit complicated network conditions to help making timeout
and dual IP stack test cases work more properly in followup changes.
Also test cases print debugging information in non-short mode like the
following:
Leaked goroutines:
net.TestWriteTimeout.func2(0xc20802a5a0, 0xc20801d000, 0x1000, 0x1000, 0xc2081d2ae0)
/go/src/net/timeout_test.go:170 +0x98
created by net.TestWriteTimeout
/go/src/net/timeout_test.go:173 +0x745
net.runDatagramPacketConnServer(0xc2080730e0, 0x2bd270, 0x3, 0x2c1770, 0xb, 0xc2081d2ba0, 0xc2081d2c00)
/go/src/net/server_test.go:398 +0x667
created by net.TestTimeoutUDP
/go/src/net/timeout_test.go:247 +0xc9
(snip)
Leaked sockets:
3: {Cookie:615726511685632 Err:<nil> SocketErr:0}
5: {Cookie:7934075906097152 Err:<nil> SocketErr:0}
Socket statistical information:
{Family:1 Type:805306370 Protocol:0 Opened:17 Accepted:0 Connected:5 Closed:17}
{Family:2 Type:805306369 Protocol:0 Opened:450 Accepted:234 Connected:279 Closed:636}
{Family:1 Type:805306369 Protocol:0 Opened:11 Accepted:5 Connected:5 Closed:16}
{Family:28 Type:805306369 Protocol:0 Opened:95 Accepted:22 Connected:16 Closed:116}
{Family:2 Type:805306370 Protocol:0 Opened:84 Accepted:0 Connected:34 Closed:83}
{Family:28 Type:805306370 Protocol:0 Opened:52 Accepted:0 Connected:4 Closed:52}
Change-Id: I0e84be59a0699bc31245c78e2249423459b8cdda
Reviewed-on: https://go-review.googlesource.com/6390
Reviewed-by: Ian Lance Taylor <iant@golang.org>
2015-02-28 20:27:01 -07:00
|
|
|
|
2014-08-29 22:12:28 -06:00
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
goLookupIP("www.example.com")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-08-29 16:50:50 -06:00
|
|
|
func BenchmarkGoLookupIPNoSuchHost(b *testing.B) {
|
2015-05-13 18:25:24 -06:00
|
|
|
testHookUninstaller.Do(uninstallTestHooks)
|
net: add socket system call hooks for testing
This change adds socket system call hooks to existing test cases for
simulating a bit complicated network conditions to help making timeout
and dual IP stack test cases work more properly in followup changes.
Also test cases print debugging information in non-short mode like the
following:
Leaked goroutines:
net.TestWriteTimeout.func2(0xc20802a5a0, 0xc20801d000, 0x1000, 0x1000, 0xc2081d2ae0)
/go/src/net/timeout_test.go:170 +0x98
created by net.TestWriteTimeout
/go/src/net/timeout_test.go:173 +0x745
net.runDatagramPacketConnServer(0xc2080730e0, 0x2bd270, 0x3, 0x2c1770, 0xb, 0xc2081d2ba0, 0xc2081d2c00)
/go/src/net/server_test.go:398 +0x667
created by net.TestTimeoutUDP
/go/src/net/timeout_test.go:247 +0xc9
(snip)
Leaked sockets:
3: {Cookie:615726511685632 Err:<nil> SocketErr:0}
5: {Cookie:7934075906097152 Err:<nil> SocketErr:0}
Socket statistical information:
{Family:1 Type:805306370 Protocol:0 Opened:17 Accepted:0 Connected:5 Closed:17}
{Family:2 Type:805306369 Protocol:0 Opened:450 Accepted:234 Connected:279 Closed:636}
{Family:1 Type:805306369 Protocol:0 Opened:11 Accepted:5 Connected:5 Closed:16}
{Family:28 Type:805306369 Protocol:0 Opened:95 Accepted:22 Connected:16 Closed:116}
{Family:2 Type:805306370 Protocol:0 Opened:84 Accepted:0 Connected:34 Closed:83}
{Family:28 Type:805306370 Protocol:0 Opened:52 Accepted:0 Connected:4 Closed:52}
Change-Id: I0e84be59a0699bc31245c78e2249423459b8cdda
Reviewed-on: https://go-review.googlesource.com/6390
Reviewed-by: Ian Lance Taylor <iant@golang.org>
2015-02-28 20:27:01 -07:00
|
|
|
|
2014-08-29 16:50:50 -06:00
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
goLookupIP("some.nonexistent")
|
|
|
|
}
|
|
|
|
}
|
2014-08-29 22:12:28 -06:00
|
|
|
|
|
|
|
func BenchmarkGoLookupIPWithBrokenNameServer(b *testing.B) {
|
2015-05-13 18:25:24 -06:00
|
|
|
testHookUninstaller.Do(uninstallTestHooks)
|
net: add socket system call hooks for testing
This change adds socket system call hooks to existing test cases for
simulating a bit complicated network conditions to help making timeout
and dual IP stack test cases work more properly in followup changes.
Also test cases print debugging information in non-short mode like the
following:
Leaked goroutines:
net.TestWriteTimeout.func2(0xc20802a5a0, 0xc20801d000, 0x1000, 0x1000, 0xc2081d2ae0)
/go/src/net/timeout_test.go:170 +0x98
created by net.TestWriteTimeout
/go/src/net/timeout_test.go:173 +0x745
net.runDatagramPacketConnServer(0xc2080730e0, 0x2bd270, 0x3, 0x2c1770, 0xb, 0xc2081d2ba0, 0xc2081d2c00)
/go/src/net/server_test.go:398 +0x667
created by net.TestTimeoutUDP
/go/src/net/timeout_test.go:247 +0xc9
(snip)
Leaked sockets:
3: {Cookie:615726511685632 Err:<nil> SocketErr:0}
5: {Cookie:7934075906097152 Err:<nil> SocketErr:0}
Socket statistical information:
{Family:1 Type:805306370 Protocol:0 Opened:17 Accepted:0 Connected:5 Closed:17}
{Family:2 Type:805306369 Protocol:0 Opened:450 Accepted:234 Connected:279 Closed:636}
{Family:1 Type:805306369 Protocol:0 Opened:11 Accepted:5 Connected:5 Closed:16}
{Family:28 Type:805306369 Protocol:0 Opened:95 Accepted:22 Connected:16 Closed:116}
{Family:2 Type:805306370 Protocol:0 Opened:84 Accepted:0 Connected:34 Closed:83}
{Family:28 Type:805306370 Protocol:0 Opened:52 Accepted:0 Connected:4 Closed:52}
Change-Id: I0e84be59a0699bc31245c78e2249423459b8cdda
Reviewed-on: https://go-review.googlesource.com/6390
Reviewed-by: Ian Lance Taylor <iant@golang.org>
2015-02-28 20:27:01 -07:00
|
|
|
|
2015-06-10 21:46:01 -06:00
|
|
|
conf, err := newResolvConfTest()
|
|
|
|
if err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
defer conf.teardown()
|
|
|
|
|
|
|
|
lines := []string{
|
|
|
|
"nameserver 203.0.113.254", // use TEST-NET-3 block, see RFC 5737
|
|
|
|
"nameserver 8.8.8.8",
|
|
|
|
}
|
|
|
|
if err := conf.writeAndUpdate(lines); err != nil {
|
|
|
|
b.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2014-08-29 22:12:28 -06:00
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
goLookupIP("www.example.com")
|
|
|
|
}
|
|
|
|
}
|