forked from folbricht/routedns
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpipeline_test.go
39 lines (30 loc) · 970 Bytes
/
pipeline_test.go
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
33
34
35
36
37
38
39
package rdns
import (
"errors"
"testing"
"time"
"github.com/miekg/dns"
"github.com/stretchr/testify/require"
)
type testDialer func(address string) (*dns.Conn, error)
func (d testDialer) Dial(address string) (*dns.Conn, error) {
return d(address)
}
func TestPipelineQueryTimeout(t *testing.T) {
df := func(address string) (*dns.Conn, error) {
time.Sleep(2 * time.Second)
return nil, errors.New("failed")
}
p := NewPipeline("test", "localhost:53", testDialer(df), time.Second)
q := new(dns.Msg)
q.SetQuestion("example.com.", dns.TypeA)
// Send some queries to start the pipeline
_, _ = p.Resolve(q)
_, _ = p.Resolve(q)
// Record when we sent the query in order to tell how long it took
start := time.Now()
_, err := p.Resolve(q)
// Make sure we get a timeout error and it took the right amount to come back
require.ErrorAs(t, err, &QueryTimeoutError{})
require.WithinDuration(t, start.Add(time.Second), time.Now(), 10*time.Millisecond)
}