mirror of
				https://github.com/coredns/coredns.git
				synced 2025-11-04 10:11:10 +01:00 
			
		
		
		
	* Clean up tests logging This cleans up the travis logs so you can see the failures better. Older tests in tests/ would call log.SetOutput(ioutil.Discard) in a haphazard way. This add log.Discard and put an `init` function in each package's dir (no way to do this globally). The cleanup in tests/ is clear. All plugins also got this init function to have some uniformity and kill any (future) logging there in the tests as well. There is a one-off in pkg/healthcheck because that does log. Signed-off-by: Miek Gieben <miek@miek.nl> * bring back original log_test.go Signed-off-by: Miek Gieben <miek@miek.nl> * suppress logging here as well Signed-off-by: Miek Gieben <miek@miek.nl>
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package test
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"testing"
 | 
						|
	"time"
 | 
						|
 | 
						|
	"github.com/miekg/dns"
 | 
						|
	"google.golang.org/grpc"
 | 
						|
 | 
						|
	"github.com/coredns/coredns/pb"
 | 
						|
)
 | 
						|
 | 
						|
func TestGrpc(t *testing.T) {
 | 
						|
	corefile := `grpc://.:0 {
 | 
						|
		whoami
 | 
						|
}
 | 
						|
`
 | 
						|
	g, _, tcp, err := CoreDNSServerAndPorts(corefile)
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("Could not get CoreDNS serving instance: %s", err)
 | 
						|
	}
 | 
						|
	defer g.Stop()
 | 
						|
 | 
						|
	conn, err := grpc.Dial(tcp, grpc.WithInsecure(), grpc.WithBlock(), grpc.WithTimeout(5*time.Second))
 | 
						|
	if err != nil {
 | 
						|
		t.Fatalf("Expected no error but got: %s", err)
 | 
						|
	}
 | 
						|
	defer conn.Close()
 | 
						|
 | 
						|
	client := pb.NewDnsServiceClient(conn)
 | 
						|
 | 
						|
	m := new(dns.Msg)
 | 
						|
	m.SetQuestion("whoami.example.org.", dns.TypeA)
 | 
						|
	msg, _ := m.Pack()
 | 
						|
 | 
						|
	reply, err := client.Query(context.TODO(), &pb.DnsPacket{Msg: msg})
 | 
						|
	if err != nil {
 | 
						|
		t.Errorf("Expected no error but got: %s", err)
 | 
						|
	}
 | 
						|
 | 
						|
	d := new(dns.Msg)
 | 
						|
	err = d.Unpack(reply.Msg)
 | 
						|
	if err != nil {
 | 
						|
		t.Errorf("Expected no error but got: %s", err)
 | 
						|
	}
 | 
						|
 | 
						|
	if d.Rcode != dns.RcodeSuccess {
 | 
						|
		t.Errorf("Expected success but got %d", d.Rcode)
 | 
						|
	}
 | 
						|
 | 
						|
	if len(d.Extra) != 2 {
 | 
						|
		t.Errorf("Expected 2 RRs in additional section, but got %d", len(d.Extra))
 | 
						|
	}
 | 
						|
}
 |