mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-30 17:53:21 -04: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))
 | |
| 	}
 | |
| }
 |