-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdelay_test.go
More file actions
63 lines (55 loc) · 1.26 KB
/
delay_test.go
File metadata and controls
63 lines (55 loc) · 1.26 KB
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
package lasr
import (
"context"
"testing"
"time"
)
func TestDelayed(t *testing.T) {
q, cleanup := newQ(t)
defer cleanup()
delayUntil := time.Now().Add(time.Millisecond * 100)
id, err := q.Delay(nil, delayUntil)
if err != nil {
t.Fatal(err)
}
tm := int64(id.(Uint64ID))
if tm, now := time.Unix(0, tm).Round(time.Hour), time.Now().Round(time.Hour); !tm.Equal(now) {
t.Errorf("bad id: %v", tm)
}
ctx, cancel := context.WithTimeout(context.Background(), time.Second*5)
defer cancel()
msg, err := q.Receive(ctx)
if err != nil {
t.Fatal(err)
}
defer func() {
if err := msg.Ack(); err != nil {
t.Fatal(err)
}
}()
if time.Now().UnixNano() < delayUntil.UnixNano() {
t.Errorf("delayed message arrived too early")
}
}
func TestWakeAtOnReloadWithDelayed_GH6(t *testing.T) {
q, cleanup := newQ(t)
defer cleanup()
nextWake := time.Now().Add(time.Hour)
_, err := q.Delay([]byte("foo"), nextWake)
if err != nil {
t.Fatal(err)
}
_, err = q.Delay([]byte("bar"), time.Now().Add(time.Hour*2))
if err != nil {
t.Fatal(err)
}
q, err = NewQ(q.db, "testing")
if err != nil {
t.Fatal(err)
}
q.waker.Lock()
if got, want := q.waker.nextWake, nextWake; !got.Equal(want) {
t.Errorf("bad nextWake: got %v, want %v", got, want)
}
q.waker.Unlock()
}