Commit 0b20aece authored by Brad Fitzpatrick's avatar Brad Fitzpatrick

net: make Resolver.PreferGo work more as documented

Fixes #24393

Change-Id: I8bcee34cdf30472663d866ed6056301d8445215c
Reviewed-on: https://go-review.googlesource.com/100875
Run-TryBot: Brad Fitzpatrick <bradfitz@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent 86a33896
...@@ -114,18 +114,19 @@ func initConfVal() { ...@@ -114,18 +114,19 @@ func initConfVal() {
// canUseCgo reports whether calling cgo functions is allowed // canUseCgo reports whether calling cgo functions is allowed
// for non-hostname lookups. // for non-hostname lookups.
func (c *conf) canUseCgo() bool { func (c *conf) canUseCgo() bool {
return c.hostLookupOrder("") == hostLookupCgo return c.hostLookupOrder(nil, "") == hostLookupCgo
} }
// hostLookupOrder determines which strategy to use to resolve hostname. // hostLookupOrder determines which strategy to use to resolve hostname.
func (c *conf) hostLookupOrder(hostname string) (ret hostLookupOrder) { // The provided Resolver is optional. nil means to not consider its options.
func (c *conf) hostLookupOrder(r *Resolver, hostname string) (ret hostLookupOrder) {
if c.dnsDebugLevel > 1 { if c.dnsDebugLevel > 1 {
defer func() { defer func() {
print("go package net: hostLookupOrder(", hostname, ") = ", ret.String(), "\n") print("go package net: hostLookupOrder(", hostname, ") = ", ret.String(), "\n")
}() }()
} }
fallbackOrder := hostLookupCgo fallbackOrder := hostLookupCgo
if c.netGo { if c.netGo || (r != nil && r.PreferGo) {
fallbackOrder = hostLookupFilesDNS fallbackOrder = hostLookupFilesDNS
} }
if c.forceCgoLookupHost || c.resolv.unknownOpt || c.goos == "android" { if c.forceCgoLookupHost || c.resolv.unknownOpt || c.goos == "android" {
......
...@@ -33,6 +33,7 @@ func TestConfHostLookupOrder(t *testing.T) { ...@@ -33,6 +33,7 @@ func TestConfHostLookupOrder(t *testing.T) {
tests := []struct { tests := []struct {
name string name string
c *conf c *conf
resolver *Resolver
hostTests []nssHostTest hostTests []nssHostTest
}{ }{
{ {
...@@ -322,6 +323,21 @@ func TestConfHostLookupOrder(t *testing.T) { ...@@ -322,6 +323,21 @@ func TestConfHostLookupOrder(t *testing.T) {
{"x.com", "myhostname", hostLookupCgo}, {"x.com", "myhostname", hostLookupCgo},
}, },
}, },
// Issue 24393: make sure "Resolver.PreferGo = true" acts like netgo.
{
name: "resolver-prefergo",
resolver: &Resolver{PreferGo: true},
c: &conf{
goos: "darwin",
forceCgoLookupHost: true, // always true for darwin
resolv: defaultResolvConf,
nss: nssStr(""),
netCgo: true,
},
hostTests: []nssHostTest{
{"localhost", "myhostname", hostLookupFilesDNS},
},
},
} }
origGetHostname := getHostname origGetHostname := getHostname
...@@ -331,7 +347,7 @@ func TestConfHostLookupOrder(t *testing.T) { ...@@ -331,7 +347,7 @@ func TestConfHostLookupOrder(t *testing.T) {
for _, ht := range tt.hostTests { for _, ht := range tt.hostTests {
getHostname = func() (string, error) { return ht.localhost, nil } getHostname = func() (string, error) { return ht.localhost, nil }
gotOrder := tt.c.hostLookupOrder(ht.host) gotOrder := tt.c.hostLookupOrder(tt.resolver, ht.host)
if gotOrder != ht.want { if gotOrder != ht.want {
t.Errorf("%s: hostLookupOrder(%q) = %v; want %v", tt.name, ht.host, gotOrder, ht.want) t.Errorf("%s: hostLookupOrder(%q) = %v; want %v", tt.name, ht.host, gotOrder, ht.want)
} }
......
...@@ -524,7 +524,7 @@ func goLookupIPFiles(name string) (addrs []IPAddr) { ...@@ -524,7 +524,7 @@ func goLookupIPFiles(name string) (addrs []IPAddr) {
// goLookupIP is the native Go implementation of LookupIP. // goLookupIP is the native Go implementation of LookupIP.
// The libc versions are in cgo_*.go. // The libc versions are in cgo_*.go.
func (r *Resolver) goLookupIP(ctx context.Context, host string) (addrs []IPAddr, err error) { func (r *Resolver) goLookupIP(ctx context.Context, host string) (addrs []IPAddr, err error) {
order := systemConf().hostLookupOrder(host) order := systemConf().hostLookupOrder(r, host)
addrs, _, err = r.goLookupIPCNAMEOrder(ctx, host, order) addrs, _, err = r.goLookupIPCNAMEOrder(ctx, host, order)
return return
} }
...@@ -676,7 +676,7 @@ func (r *Resolver) goLookupIPCNAMEOrder(ctx context.Context, name string, order ...@@ -676,7 +676,7 @@ func (r *Resolver) goLookupIPCNAMEOrder(ctx context.Context, name string, order
// goLookupCNAME is the native Go (non-cgo) implementation of LookupCNAME. // goLookupCNAME is the native Go (non-cgo) implementation of LookupCNAME.
func (r *Resolver) goLookupCNAME(ctx context.Context, host string) (string, error) { func (r *Resolver) goLookupCNAME(ctx context.Context, host string) (string, error) {
order := systemConf().hostLookupOrder(host) order := systemConf().hostLookupOrder(r, host)
_, cname, err := r.goLookupIPCNAMEOrder(ctx, host, order) _, cname, err := r.goLookupIPCNAMEOrder(ctx, host, order)
return cname.String(), err return cname.String(), err
} }
......
...@@ -74,7 +74,7 @@ func (r *Resolver) dial(ctx context.Context, network, server string) (Conn, erro ...@@ -74,7 +74,7 @@ func (r *Resolver) dial(ctx context.Context, network, server string) (Conn, erro
} }
func (r *Resolver) lookupHost(ctx context.Context, host string) (addrs []string, err error) { func (r *Resolver) lookupHost(ctx context.Context, host string) (addrs []string, err error) {
order := systemConf().hostLookupOrder(host) order := systemConf().hostLookupOrder(r, host)
if !r.PreferGo && order == hostLookupCgo { if !r.PreferGo && order == hostLookupCgo {
if addrs, err, ok := cgoLookupHost(ctx, host); ok { if addrs, err, ok := cgoLookupHost(ctx, host); ok {
return addrs, err return addrs, err
...@@ -89,7 +89,7 @@ func (r *Resolver) lookupIP(ctx context.Context, host string) (addrs []IPAddr, e ...@@ -89,7 +89,7 @@ func (r *Resolver) lookupIP(ctx context.Context, host string) (addrs []IPAddr, e
if r.PreferGo { if r.PreferGo {
return r.goLookupIP(ctx, host) return r.goLookupIP(ctx, host)
} }
order := systemConf().hostLookupOrder(host) order := systemConf().hostLookupOrder(r, host)
if order == hostLookupCgo { if order == hostLookupCgo {
if addrs, err, ok := cgoLookupIP(ctx, host); ok { if addrs, err, ok := cgoLookupIP(ctx, host); ok {
return addrs, err return addrs, err
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment