2017-04-18 11:10:49 -04:00
|
|
|
package dnsserver
|
|
|
|
|
|
|
|
|
|
import (
|
2018-04-20 11:01:06 +01:00
|
|
|
"context"
|
2017-04-18 11:10:49 -04:00
|
|
|
"testing"
|
2017-10-21 09:30:59 +01:00
|
|
|
|
|
|
|
|
"github.com/coredns/coredns/plugin"
|
2020-08-24 09:12:00 +02:00
|
|
|
"github.com/coredns/coredns/plugin/pkg/log"
|
2017-10-21 09:30:59 +01:00
|
|
|
"github.com/coredns/coredns/plugin/test"
|
|
|
|
|
|
|
|
|
|
"github.com/miekg/dns"
|
2017-04-18 11:10:49 -04:00
|
|
|
)
|
|
|
|
|
|
2017-10-21 09:30:59 +01:00
|
|
|
type testPlugin struct{}
|
|
|
|
|
|
|
|
|
|
func (tp testPlugin) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
|
|
|
|
|
return 0, nil
|
|
|
|
|
}
|
|
|
|
|
|
2024-10-25 00:48:56 +05:30
|
|
|
func (tp testPlugin) Name() string { return "local" }
|
2017-10-21 09:30:59 +01:00
|
|
|
|
2017-10-24 10:16:03 +01:00
|
|
|
func testConfig(transport string, p plugin.Handler) *Config {
|
2017-10-21 09:30:59 +01:00
|
|
|
c := &Config{
|
2018-02-14 14:19:32 -05:00
|
|
|
Zone: "example.com.",
|
|
|
|
|
Transport: transport,
|
|
|
|
|
ListenHosts: []string{"127.0.0.1"},
|
|
|
|
|
Port: "53",
|
|
|
|
|
Debug: false,
|
2022-05-24 14:36:36 +02:00
|
|
|
Stacktrace: false,
|
2017-10-21 09:30:59 +01:00
|
|
|
}
|
|
|
|
|
|
2017-10-24 10:16:03 +01:00
|
|
|
c.AddPlugin(func(next plugin.Handler) plugin.Handler { return p })
|
2017-10-21 09:30:59 +01:00
|
|
|
return c
|
2017-04-18 11:10:49 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestNewServer(t *testing.T) {
|
2017-10-24 10:16:03 +01:00
|
|
|
_, err := NewServer("127.0.0.1:53", []*Config{testConfig("dns", testPlugin{})})
|
2017-04-18 11:10:49 -04:00
|
|
|
if err != nil {
|
2017-10-24 10:16:03 +01:00
|
|
|
t.Errorf("Expected no error for NewServer, got %s", err)
|
2017-04-18 11:10:49 -04:00
|
|
|
}
|
|
|
|
|
|
2017-10-24 10:16:03 +01:00
|
|
|
_, err = NewServergRPC("127.0.0.1:53", []*Config{testConfig("grpc", testPlugin{})})
|
2017-04-18 11:10:49 -04:00
|
|
|
if err != nil {
|
2017-10-24 10:16:03 +01:00
|
|
|
t.Errorf("Expected no error for NewServergRPC, got %s", err)
|
2017-04-18 11:10:49 -04:00
|
|
|
}
|
|
|
|
|
|
2017-10-24 10:16:03 +01:00
|
|
|
_, err = NewServerTLS("127.0.0.1:53", []*Config{testConfig("tls", testPlugin{})})
|
2017-04-18 11:10:49 -04:00
|
|
|
if err != nil {
|
2017-10-24 10:16:03 +01:00
|
|
|
t.Errorf("Expected no error for NewServerTLS, got %s", err)
|
2017-04-18 11:10:49 -04:00
|
|
|
}
|
2023-07-31 16:34:31 -03:00
|
|
|
|
|
|
|
|
_, err = NewServerQUIC("127.0.0.1:53", []*Config{testConfig("quic", testPlugin{})})
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Errorf("Expected no error for NewServerQUIC, got %s", err)
|
|
|
|
|
}
|
2017-04-18 11:10:49 -04:00
|
|
|
}
|
2017-10-21 09:30:59 +01:00
|
|
|
|
2020-08-24 09:12:00 +02:00
|
|
|
func TestDebug(t *testing.T) {
|
|
|
|
|
configNoDebug, configDebug := testConfig("dns", testPlugin{}), testConfig("dns", testPlugin{})
|
|
|
|
|
configDebug.Debug = true
|
|
|
|
|
|
|
|
|
|
s1, err := NewServer("127.0.0.1:53", []*Config{configDebug, configNoDebug})
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Errorf("Expected no error for NewServer, got %s", err)
|
|
|
|
|
}
|
|
|
|
|
if !s1.debug {
|
|
|
|
|
t.Errorf("Expected debug mode enabled for server s1")
|
|
|
|
|
}
|
|
|
|
|
if !log.D.Value() {
|
|
|
|
|
t.Errorf("Expected debug logging enabled")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
s2, err := NewServer("127.0.0.1:53", []*Config{configNoDebug})
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Errorf("Expected no error for NewServer, got %s", err)
|
|
|
|
|
}
|
|
|
|
|
if s2.debug {
|
|
|
|
|
t.Errorf("Expected debug mode disabled for server s2")
|
|
|
|
|
}
|
|
|
|
|
if log.D.Value() {
|
|
|
|
|
t.Errorf("Expected debug logging disabled")
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-05-24 14:36:36 +02:00
|
|
|
func TestStacktrace(t *testing.T) {
|
|
|
|
|
configNoStacktrace, configStacktrace := testConfig("dns", testPlugin{}), testConfig("dns", testPlugin{})
|
|
|
|
|
configStacktrace.Stacktrace = true
|
|
|
|
|
|
|
|
|
|
s1, err := NewServer("127.0.0.1:53", []*Config{configStacktrace, configStacktrace})
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Errorf("Expected no error for NewServer, got %s", err)
|
|
|
|
|
}
|
|
|
|
|
if !s1.stacktrace {
|
|
|
|
|
t.Errorf("Expected stacktrace mode enabled for server s1")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
s2, err := NewServer("127.0.0.1:53", []*Config{configNoStacktrace})
|
|
|
|
|
if err != nil {
|
|
|
|
|
t.Errorf("Expected no error for NewServer, got %s", err)
|
|
|
|
|
}
|
|
|
|
|
if s2.stacktrace {
|
|
|
|
|
t.Errorf("Expected stacktrace disabled for server s2")
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-10-21 09:30:59 +01:00
|
|
|
func BenchmarkCoreServeDNS(b *testing.B) {
|
2017-10-24 10:16:03 +01:00
|
|
|
s, err := NewServer("127.0.0.1:53", []*Config{testConfig("dns", testPlugin{})})
|
2017-10-21 09:30:59 +01:00
|
|
|
if err != nil {
|
2017-10-24 10:16:03 +01:00
|
|
|
b.Errorf("Expected no error for NewServer, got %s", err)
|
2017-10-21 09:30:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ctx := context.TODO()
|
|
|
|
|
w := &test.ResponseWriter{}
|
|
|
|
|
m := new(dns.Msg)
|
|
|
|
|
m.SetQuestion("aaa.example.com.", dns.TypeTXT)
|
|
|
|
|
|
|
|
|
|
b.ReportAllocs()
|
|
|
|
|
b.ResetTimer()
|
2025-05-29 03:50:55 +03:00
|
|
|
for range b.N {
|
2017-10-21 09:30:59 +01:00
|
|
|
s.ServeDNS(ctx, w, m)
|
|
|
|
|
}
|
|
|
|
|
}
|