aboutsummaryrefslogtreecommitdiff
path: root/middleware/dnssec/cache_test.go
blob: 0039586d569b2412974171952517ffe60cc8ae00 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
package dnssec

import (
	"testing"
	"time"

	"github.com/miekg/coredns/middleware"
	"github.com/miekg/coredns/middleware/test"
)

func TestCacheSet(t *testing.T) {
	fPriv, rmPriv, _ := test.TempFile(t, ".", privKey)
	fPub, rmPub, _ := test.TempFile(t, ".", pubKey)
	defer rmPriv()
	defer rmPub()

	dnskey, err := ParseKeyFile(fPub, fPriv)
	if err != nil {
		t.Fatalf("failed to parse key: %v\n", err)
	}

	m := testMsg()
	state := middleware.State{Req: m}
	k := key(m.Answer) // calculate *before* we add the sig
	d := NewDnssec([]string{"miek.nl."}, []*DNSKEY{dnskey}, nil)
	m = d.Sign(state, "miek.nl.", time.Now().UTC())

	_, ok := d.get(k)
	if !ok {
		t.Errorf("signature was not added to the cache")
	}
}