mirror of
				https://github.com/coredns/coredns.git
				synced 2025-11-03 02:33:21 -05:00 
			
		
		
		
	* Remove internal loop detection I can't actually think of a situation where we can create an internal loop. Sure externally triggered cycles can happen, but this is where the *loop* plugin comes in that detects those. Fixes #2602 Signed-off-by: Miek Gieben <miek@miek.nl> * Remove test Signed-off-by: Miek Gieben <miek@miek.nl>
		
			
				
	
	
		
			68 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package dnsserver
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"testing"
 | 
						|
 | 
						|
	"github.com/coredns/coredns/plugin"
 | 
						|
	"github.com/coredns/coredns/plugin/test"
 | 
						|
 | 
						|
	"github.com/miekg/dns"
 | 
						|
)
 | 
						|
 | 
						|
type testPlugin struct{}
 | 
						|
 | 
						|
func (tp testPlugin) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
 | 
						|
	return 0, nil
 | 
						|
}
 | 
						|
 | 
						|
func (tp testPlugin) Name() string { return "testplugin" }
 | 
						|
 | 
						|
func testConfig(transport string, p plugin.Handler) *Config {
 | 
						|
	c := &Config{
 | 
						|
		Zone:        "example.com.",
 | 
						|
		Transport:   transport,
 | 
						|
		ListenHosts: []string{"127.0.0.1"},
 | 
						|
		Port:        "53",
 | 
						|
		Debug:       false,
 | 
						|
	}
 | 
						|
 | 
						|
	c.AddPlugin(func(next plugin.Handler) plugin.Handler { return p })
 | 
						|
	return c
 | 
						|
}
 | 
						|
 | 
						|
func TestNewServer(t *testing.T) {
 | 
						|
	_, err := NewServer("127.0.0.1:53", []*Config{testConfig("dns", testPlugin{})})
 | 
						|
	if err != nil {
 | 
						|
		t.Errorf("Expected no error for NewServer, got %s", err)
 | 
						|
	}
 | 
						|
 | 
						|
	_, err = NewServergRPC("127.0.0.1:53", []*Config{testConfig("grpc", testPlugin{})})
 | 
						|
	if err != nil {
 | 
						|
		t.Errorf("Expected no error for NewServergRPC, got %s", err)
 | 
						|
	}
 | 
						|
 | 
						|
	_, err = NewServerTLS("127.0.0.1:53", []*Config{testConfig("tls", testPlugin{})})
 | 
						|
	if err != nil {
 | 
						|
		t.Errorf("Expected no error for NewServerTLS, got %s", err)
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
func BenchmarkCoreServeDNS(b *testing.B) {
 | 
						|
	s, err := NewServer("127.0.0.1:53", []*Config{testConfig("dns", testPlugin{})})
 | 
						|
	if err != nil {
 | 
						|
		b.Errorf("Expected no error for NewServer, got %s", err)
 | 
						|
	}
 | 
						|
 | 
						|
	ctx := context.TODO()
 | 
						|
	w := &test.ResponseWriter{}
 | 
						|
	m := new(dns.Msg)
 | 
						|
	m.SetQuestion("aaa.example.com.", dns.TypeTXT)
 | 
						|
 | 
						|
	b.ReportAllocs()
 | 
						|
	b.ResetTimer()
 | 
						|
	for i := 0; i < b.N; i++ {
 | 
						|
		s.ServeDNS(ctx, w, m)
 | 
						|
	}
 | 
						|
}
 |