| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | package cache | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"context" | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/coredns/coredns/plugin" | 
					
						
							|  |  |  | 	"github.com/coredns/coredns/plugin/pkg/dnstest" | 
					
						
							|  |  |  | 	"github.com/coredns/coredns/plugin/test" | 
					
						
							| 
									
										
										
										
											2022-10-21 09:29:04 -06:00
										 |  |  | 	"github.com/coredns/coredns/request" | 
					
						
							| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/miekg/dns" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestResponseWithDNSSEC(t *testing.T) { | 
					
						
							|  |  |  | 	// We do 2 queries, one where we want non-dnssec and one with dnssec and check the responses in each of them | 
					
						
							|  |  |  | 	var tcs = []test.Case{ | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			Qname: "invent.example.org.", Qtype: dns.TypeA, | 
					
						
							|  |  |  | 			Answer: []dns.RR{ | 
					
						
							|  |  |  | 				test.CNAME("invent.example.org.		1781	IN	CNAME	leptone.example.org."), | 
					
						
							|  |  |  | 				test.A("leptone.example.org.	1781	IN	A	195.201.182.103"), | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			Qname: "invent.example.org.", Qtype: dns.TypeA, | 
					
						
							| 
									
										
										
										
											2021-07-09 04:53:50 -04:00
										 |  |  | 			Do:                true, | 
					
						
							|  |  |  | 			AuthenticatedData: true, | 
					
						
							| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | 			Answer: []dns.RR{ | 
					
						
							|  |  |  | 				test.CNAME("invent.example.org.		1781	IN	CNAME	leptone.example.org."), | 
					
						
							|  |  |  | 				test.RRSIG("invent.example.org.		1781	IN	RRSIG	CNAME 8 3 1800 20201012085750 20200912082613 57411 example.org. ijSv5FmsNjFviBcOFwQgqjt073lttxTTNqkno6oMa3DD3kC+"), | 
					
						
							|  |  |  | 				test.A("leptone.example.org.	1781	IN	A	195.201.182.103"), | 
					
						
							|  |  |  | 				test.RRSIG("leptone.example.org.	1781	IN	RRSIG	A 8 3 1800 20201012093630 20200912083827 57411 example.org. eLuSOkLAzm/WIOpaZD3/4TfvKP1HAFzjkis9LIJSRVpQt307dm9WY9"), | 
					
						
							|  |  |  | 			}, | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c := New() | 
					
						
							|  |  |  | 	c.Next = dnssecHandler() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for i, tc := range tcs { | 
					
						
							|  |  |  | 		m := tc.Msg() | 
					
						
							|  |  |  | 		rec := dnstest.NewRecorder(&test.ResponseWriter{}) | 
					
						
							|  |  |  | 		c.ServeDNS(context.TODO(), rec, m) | 
					
						
							| 
									
										
										
										
											2021-07-09 04:53:50 -04:00
										 |  |  | 		if tc.AuthenticatedData != rec.Msg.AuthenticatedData { | 
					
						
							|  |  |  | 			t.Errorf("Test %d, expected AuthenticatedData=%v", i, tc.AuthenticatedData) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | 		if err := test.Section(tc, test.Answer, rec.Msg.Answer); err != nil { | 
					
						
							|  |  |  | 			t.Errorf("Test %d, expected no error, got %s", i, err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// now do the reverse | 
					
						
							|  |  |  | 	c = New() | 
					
						
							|  |  |  | 	c.Next = dnssecHandler() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for i, tc := range []test.Case{tcs[1], tcs[0]} { | 
					
						
							|  |  |  | 		m := tc.Msg() | 
					
						
							|  |  |  | 		rec := dnstest.NewRecorder(&test.ResponseWriter{}) | 
					
						
							|  |  |  | 		c.ServeDNS(context.TODO(), rec, m) | 
					
						
							|  |  |  | 		if err := test.Section(tc, test.Answer, rec.Msg.Answer); err != nil { | 
					
						
							|  |  |  | 			t.Errorf("Test %d, expected no error, got %s", i, err) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func dnssecHandler() plugin.Handler { | 
					
						
							|  |  |  | 	return plugin.HandlerFunc(func(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) { | 
					
						
							|  |  |  | 		m := new(dns.Msg) | 
					
						
							|  |  |  | 		m.SetQuestion("example.org.", dns.TypeA) | 
					
						
							| 
									
										
										
										
											2022-10-21 09:29:04 -06:00
										 |  |  | 		state := request.Request{W: &test.ResponseWriter{}, Req: r} | 
					
						
							| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-09 04:53:50 -04:00
										 |  |  | 		m.AuthenticatedData = true | 
					
						
							| 
									
										
										
										
											2022-10-21 09:29:04 -06:00
										 |  |  | 		// If query has the DO bit, then send DNSSEC responses (RRSIGs) | 
					
						
							|  |  |  | 		if state.Do() { | 
					
						
							|  |  |  | 			m.Answer = make([]dns.RR, 4) | 
					
						
							|  |  |  | 			m.Answer[0] = test.CNAME("invent.example.org.		1781	IN	CNAME	leptone.example.org.") | 
					
						
							|  |  |  | 			m.Answer[1] = test.RRSIG("invent.example.org.		1781	IN	RRSIG	CNAME 8 3 1800 20201012085750 20200912082613 57411 example.org. ijSv5FmsNjFviBcOFwQgqjt073lttxTTNqkno6oMa3DD3kC+") | 
					
						
							|  |  |  | 			m.Answer[2] = test.A("leptone.example.org.	1781	IN	A	195.201.182.103") | 
					
						
							|  |  |  | 			m.Answer[3] = test.RRSIG("leptone.example.org.	1781	IN	RRSIG	A 8 3 1800 20201012093630 20200912083827 57411 example.org. eLuSOkLAzm/WIOpaZD3/4TfvKP1HAFzjkis9LIJSRVpQt307dm9WY9") | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			m.Answer = make([]dns.RR, 2) | 
					
						
							|  |  |  | 			m.Answer[0] = test.CNAME("invent.example.org.		1781	IN	CNAME	leptone.example.org.") | 
					
						
							|  |  |  | 			m.Answer[1] = test.A("leptone.example.org.	1781	IN	A	195.201.182.103") | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | 		w.WriteMsg(m) | 
					
						
							|  |  |  | 		return dns.RcodeSuccess, nil | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-21 09:29:04 -06:00
										 |  |  | func TestFilterRRSlice(t *testing.T) { | 
					
						
							| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | 	rrs := []dns.RR{ | 
					
						
							|  |  |  | 		test.CNAME("invent.example.org.		1781	IN	CNAME	leptone.example.org."), | 
					
						
							|  |  |  | 		test.RRSIG("invent.example.org.		1781	IN	RRSIG	CNAME 8 3 1800 20201012085750 20200912082613 57411 example.org. ijSv5FmsNjFviBcOFwQgqjt073lttxTTNqkno6oMa3DD3kC+"), | 
					
						
							|  |  |  | 		test.A("leptone.example.org.	1781	IN	A	195.201.182.103"), | 
					
						
							|  |  |  | 		test.RRSIG("leptone.example.org.	1781	IN	RRSIG	A 8 3 1800 20201012093630 20200912083827 57411 example.org. eLuSOkLAzm/WIOpaZD3/4TfvKP1HAFzjkis9LIJSRVpQt307dm9WY9"), | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-21 09:29:04 -06:00
										 |  |  | 	filter1 := filterRRSlice(rrs, 0, false) | 
					
						
							| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | 	if len(filter1) != 4 { | 
					
						
							|  |  |  | 		t.Errorf("Expected 4 RRs after filtering, got %d", len(filter1)) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	rrsig := 0 | 
					
						
							|  |  |  | 	for _, f := range filter1 { | 
					
						
							|  |  |  | 		if f.Header().Rrtype == dns.TypeRRSIG { | 
					
						
							|  |  |  | 			rrsig++ | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if rrsig != 2 { | 
					
						
							|  |  |  | 		t.Errorf("Expected 2 RRSIGs after filtering, got %d", rrsig) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-21 09:29:04 -06:00
										 |  |  | 	filter2 := filterRRSlice(rrs, 0, false) | 
					
						
							|  |  |  | 	if len(filter2) != 4 { | 
					
						
							|  |  |  | 		t.Errorf("Expected 4 RRs after filtering, got %d", len(filter2)) | 
					
						
							| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	rrsig = 0 | 
					
						
							|  |  |  | 	for _, f := range filter2 { | 
					
						
							|  |  |  | 		if f.Header().Rrtype == dns.TypeRRSIG { | 
					
						
							|  |  |  | 			rrsig++ | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2022-10-21 09:29:04 -06:00
										 |  |  | 	if rrsig != 2 { | 
					
						
							|  |  |  | 		t.Errorf("Expected 2 RRSIGs after filtering, got %d", rrsig) | 
					
						
							| 
									
										
										
										
											2020-09-28 16:53:00 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | } |