Fix a flaky test by not depending on Google (#2565)
TestLookupAutoPathErratic sometimes fail on TravisCI saying below ``` === RUN TestLookupAutoPathErratic --- FAIL: TestLookupAutoPathErratic (8.30s) erratic_autopath_test.go:39: Test 0, failed to sent query: "read udp [::1]:39758->[::1]:56643: i/o timeout" FAIL ``` The failure happens when Google replies slowly. This PR changes to not use Google but run CoreDNS locally and proxy to the server. --- Because the failure depends on Google, sometimes it happens frequently but sometimes it doesn't happen. I hope following test help you reproduce it. ``` func TestLookupAutoPathErratic2(t *testing.T) { for i := 0; i < 200; i++ { TestLookupAutoPathErratic(t) } } ``` or I can reproduce it by changing proxy to other DNS like 1.1.1.1 instead of 8.8.8.8 too
This commit is contained in:
parent
d42d80c4f6
commit
643dfd7419
1 changed files with 90 additions and 50 deletions
|
@ -1,80 +1,120 @@
|
||||||
package test
|
package test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/miekg/dns"
|
"github.com/miekg/dns"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestLookupAutoPathErratic(t *testing.T) {
|
func setupProxyTargetCoreDNS(t *testing.T, fn func(string)) {
|
||||||
|
tmpdir, err := ioutil.TempDir(os.TempDir(), "coredns")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
defer os.Remove(tmpdir)
|
||||||
|
|
||||||
|
content := `
|
||||||
|
example.org. IN SOA sns.dns.icann.org. noc.dns.icann.org. 1 3600 3600 3600 3600
|
||||||
|
|
||||||
|
google.com. IN SOA ns1.google.com. dns-admin.google.com. 1 3600 3600 3600 3600
|
||||||
|
google.com. IN A 172.217.25.110
|
||||||
|
`
|
||||||
|
|
||||||
|
path := filepath.Join(tmpdir, "file")
|
||||||
|
if err = ioutil.WriteFile(path, []byte(content), 0644); err != nil {
|
||||||
|
t.Fatalf("Could not write to temp file: %s", err)
|
||||||
|
}
|
||||||
|
defer os.Remove(path)
|
||||||
|
|
||||||
corefile := `.:0 {
|
corefile := `.:0 {
|
||||||
erratic
|
file ` + path + `
|
||||||
autopath @erratic
|
}
|
||||||
proxy . 8.8.8.8:53
|
|
||||||
debug
|
|
||||||
}
|
|
||||||
`
|
`
|
||||||
i, udp, _, err := CoreDNSServerAndPorts(corefile)
|
i, udp, _, err := CoreDNSServerAndPorts(corefile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Could not get CoreDNS serving instance: %s", err)
|
t.Fatalf("Could not get proxy target CoreDNS serving instance: %s", err)
|
||||||
}
|
}
|
||||||
defer i.Stop()
|
defer i.Stop()
|
||||||
|
|
||||||
tests := []struct {
|
fn(udp)
|
||||||
qname string
|
}
|
||||||
expectedAnswer string
|
|
||||||
expectedType uint16
|
|
||||||
}{
|
|
||||||
{"google.com.a.example.org.", "google.com.a.example.org.", dns.TypeCNAME},
|
|
||||||
{"google.com.", "google.com.", dns.TypeA},
|
|
||||||
}
|
|
||||||
|
|
||||||
for i, tc := range tests {
|
func TestLookupAutoPathErratic(t *testing.T) {
|
||||||
m := new(dns.Msg)
|
setupProxyTargetCoreDNS(t, func(proxyPath string) {
|
||||||
// erratic always returns this search path: "a.example.org.", "b.example.org.", "".
|
corefile := `.:0 {
|
||||||
m.SetQuestion(tc.qname, dns.TypeA)
|
erratic
|
||||||
|
autopath @erratic
|
||||||
r, err := dns.Exchange(m, udp)
|
proxy . ` + proxyPath + `
|
||||||
|
debug
|
||||||
|
}
|
||||||
|
`
|
||||||
|
i, udp, _, err := CoreDNSServerAndPorts(corefile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Test %d, failed to sent query: %q", i, err)
|
t.Fatalf("Could not get CoreDNS serving instance: %s", err)
|
||||||
}
|
}
|
||||||
if len(r.Answer) == 0 {
|
defer i.Stop()
|
||||||
t.Fatalf("Test %d, answer section should have RRs", i)
|
|
||||||
|
tests := []struct {
|
||||||
|
qname string
|
||||||
|
expectedAnswer string
|
||||||
|
expectedType uint16
|
||||||
|
}{
|
||||||
|
{"google.com.a.example.org.", "google.com.a.example.org.", dns.TypeCNAME},
|
||||||
|
{"google.com.", "google.com.", dns.TypeA},
|
||||||
}
|
}
|
||||||
if x := r.Answer[0].Header().Name; x != tc.expectedAnswer {
|
|
||||||
t.Fatalf("Test %d, expected answer %s, got %s", i, tc.expectedAnswer, x)
|
for i, tc := range tests {
|
||||||
|
m := new(dns.Msg)
|
||||||
|
// erratic always returns this search path: "a.example.org.", "b.example.org.", "".
|
||||||
|
m.SetQuestion(tc.qname, dns.TypeA)
|
||||||
|
|
||||||
|
r, err := dns.Exchange(m, udp)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Test %d, failed to sent query: %q", i, err)
|
||||||
|
}
|
||||||
|
if len(r.Answer) == 0 {
|
||||||
|
t.Fatalf("Test %d, answer section should have RRs", i)
|
||||||
|
}
|
||||||
|
if x := r.Answer[0].Header().Name; x != tc.expectedAnswer {
|
||||||
|
t.Fatalf("Test %d, expected answer %s, got %s", i, tc.expectedAnswer, x)
|
||||||
|
}
|
||||||
|
if x := r.Answer[0].Header().Rrtype; x != tc.expectedType {
|
||||||
|
t.Fatalf("Test %d, expected answer type %d, got %d", i, tc.expectedType, x)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if x := r.Answer[0].Header().Rrtype; x != tc.expectedType {
|
})
|
||||||
t.Fatalf("Test %d, expected answer type %d, got %d", i, tc.expectedType, x)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestAutoPathErraticNotLoaded(t *testing.T) {
|
func TestAutoPathErraticNotLoaded(t *testing.T) {
|
||||||
corefile := `.:0 {
|
setupProxyTargetCoreDNS(t, func(proxyPath string) {
|
||||||
|
corefile := `.:0 {
|
||||||
autopath @erratic
|
autopath @erratic
|
||||||
proxy . 8.8.8.8:53
|
proxy . ` + proxyPath + `
|
||||||
debug
|
debug
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
i, err := CoreDNSServer(corefile)
|
i, err := CoreDNSServer(corefile)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Could not get CoreDNS serving instance: %s", err)
|
t.Fatalf("Could not get CoreDNS serving instance: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
udp, _ := CoreDNSServerPorts(i, 0)
|
udp, _ := CoreDNSServerPorts(i, 0)
|
||||||
if udp == "" {
|
if udp == "" {
|
||||||
t.Fatalf("Could not get UDP listening port")
|
t.Fatalf("Could not get UDP listening port")
|
||||||
}
|
}
|
||||||
defer i.Stop()
|
defer i.Stop()
|
||||||
|
|
||||||
m := new(dns.Msg)
|
m := new(dns.Msg)
|
||||||
m.SetQuestion("google.com.a.example.org.", dns.TypeA)
|
m.SetQuestion("google.com.a.example.org.", dns.TypeA)
|
||||||
r, err := dns.Exchange(m, udp)
|
r, err := dns.Exchange(m, udp)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Failed to sent query: %q", err)
|
t.Fatalf("Failed to sent query: %q", err)
|
||||||
}
|
}
|
||||||
if r.Rcode != dns.RcodeNameError {
|
if r.Rcode != dns.RcodeNameError {
|
||||||
t.Fatalf("Expected NXDOMAIN, got %d", r.Rcode)
|
t.Fatalf("Expected NXDOMAIN, got %d", r.Rcode)
|
||||||
}
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue