diff options
Diffstat (limited to 'plugin/pkg/doh/doh_test.go')
-rw-r--r-- | plugin/pkg/doh/doh_test.go | 76 |
1 files changed, 35 insertions, 41 deletions
diff --git a/plugin/pkg/doh/doh_test.go b/plugin/pkg/doh/doh_test.go index 449166151..047d0136d 100644 --- a/plugin/pkg/doh/doh_test.go +++ b/plugin/pkg/doh/doh_test.go @@ -7,46 +7,40 @@ import ( "github.com/miekg/dns" ) -func TestPostRequest(t *testing.T) { - m := new(dns.Msg) - m.SetQuestion("example.org.", dns.TypeDNSKEY) - - req, err := NewRequest(http.MethodPost, "https://example.org:443", m) - if err != nil { - t.Errorf("Failure to make request: %s", err) - } - - m, err = RequestToMsg(req) - if err != nil { - t.Fatalf("Failure to get message from request: %s", err) - } - - if x := m.Question[0].Name; x != "example.org." { - t.Errorf("Qname expected %s, got %s", "example.org.", x) - } - if x := m.Question[0].Qtype; x != dns.TypeDNSKEY { - t.Errorf("Qname expected %d, got %d", x, dns.TypeDNSKEY) - } -} - -func TestGetRequest(t *testing.T) { - m := new(dns.Msg) - m.SetQuestion("example.org.", dns.TypeDNSKEY) - - req, err := NewRequest(http.MethodGet, "https://example.org:443", m) - if err != nil { - t.Errorf("Failure to make request: %s", err) - } - - m, err = RequestToMsg(req) - if err != nil { - t.Fatalf("Failure to get message from request: %s", err) - } - - if x := m.Question[0].Name; x != "example.org." { - t.Errorf("Qname expected %s, got %s", "example.org.", x) - } - if x := m.Question[0].Qtype; x != dns.TypeDNSKEY { - t.Errorf("Qname expected %d, got %d", x, dns.TypeDNSKEY) +func TestDoH(t *testing.T) { + tests := map[string]struct { + method string + url string + }{ + "POST request over HTTPS": {method: http.MethodPost, url: "https://example.org:443"}, + "POST request over HTTP": {method: http.MethodPost, url: "http://example.org:443"}, + "POST request without protocol": {method: http.MethodPost, url: "example.org:443"}, + "GET request over HTTPS": {method: http.MethodGet, url: "https://example.org:443"}, + "GET request over HTTP": {method: http.MethodGet, url: "http://example.org"}, + "GET request without protocol": {method: http.MethodGet, url: "example.org:443"}, + } + + for name, test := range tests { + t.Run(name, func(t *testing.T) { + m := new(dns.Msg) + m.SetQuestion("example.org.", dns.TypeDNSKEY) + + req, err := NewRequest(test.method, test.url, m) + if err != nil { + t.Errorf("Failure to make request: %s", err) + } + + m, err = RequestToMsg(req) + if err != nil { + t.Fatalf("Failure to get message from request: %s", err) + } + + if x := m.Question[0].Name; x != "example.org." { + t.Errorf("Qname expected %s, got %s", "example.org.", x) + } + if x := m.Question[0].Qtype; x != dns.TypeDNSKEY { + t.Errorf("Qname expected %d, got %d", x, dns.TypeDNSKEY) + } + }) } } |