-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjob_test.go
125 lines (94 loc) · 3.26 KB
/
job_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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
package jobq
import (
"context"
"errors"
"testing"
"time"
"github.com/stretchr/testify/assert"
)
// DummyTask for testing
type DummyTask struct {
result interface{}
err error
delay time.Duration // delay before returning result
}
func (dt *DummyTask) Execute(ctx context.Context) (interface{}, error) {
time.Sleep(dt.delay)
return dt.result, dt.err
}
func TestJobQueue_NewJobQueue(t *testing.T) {
q, err := NewJobQueue(&JobQueueOptions{
Queue: NewFIFOQueue(1),
})
assert.Nil(t, err, "Expected no error from NewJobQueue")
assert.NotNil(t, q, "Expected a non-nil JobQueue")
q.Close()
_, err = NewJobQueue(&JobQueueOptions{})
assert.NotNil(t, err, "Expected an error from NewJobQueue")
}
func TestJobQueue_GetStatus(t *testing.T) {
task := &DummyTask{}
job, _ := NewJob(&JobOptions{Task: task})
assert.Equal(t, StatusPending, job.GetStatus(), "Job should have status StatusRunning")
}
func TestJobQueue_SetStatus(t *testing.T) {
task := &DummyTask{}
job, _ := NewJob(&JobOptions{Task: task})
job.SetStatus(StatusRunning)
assert.Equal(t, StatusRunning, job.GetStatus(), "Job should have status StatusRunning")
}
func TestJobQueue_Len(t *testing.T) {
q, err := NewJobQueue(&JobQueueOptions{
Queue: NewFIFOQueue(1),
})
assert.Nil(t, err, "Expected no error from NewJobQueue")
assert.Equal(t, 0, q.Len(), "JobQueue length should be 0")
task := &DummyTask{}
q.EnqueueJob(&JobOptions{Task: task})
assert.Equal(t, 1, q.Len(), "JobQueue length should be 1 after enqueuing a job")
q.Close()
}
func TestJob_Empty(t *testing.T) {
task := &DummyTask{}
job, _ := NewJob(&JobOptions{Task: task})
assert.False(t, job.Empty(), "Job should not be empty")
job.Task = nil
assert.True(t, job.Empty(), "Job should be empty")
}
func TestJob_Result(t *testing.T) {
task := &DummyTask{result: "success"}
job, _ := NewJob(&JobOptions{Task: task})
job.Run()
result, err := job.Result()
assert.Nil(t, err, "Job should not return an error")
assert.Equal(t, "success", result, "Job should return the task's result")
}
func TestJob_Run(t *testing.T) {
task := &DummyTask{result: "success", delay: 10 * time.Millisecond}
job, _ := NewJob(&JobOptions{Task: task})
go job.Run()
result, err := job.Future.Result()
assert.Nil(t, err, "Job should not return an error")
assert.Equal(t, "success", result, "Job should return the task's result")
}
func TestJob_Run_withRetries(t *testing.T) {
task := &DummyTask{result: "success", delay: 10 * time.Millisecond}
job, _ := NewJob(&JobOptions{Task: task})
go job.Run()
result, err := job.Future.Result()
assert.Nil(t, err, "Job should not return an error")
assert.Equal(t, "success", result, "Job should return the task's result")
assert.Equal(t, 0, job.retries, "Job should have 1 retries")
assert.Equal(t, 1, job.maxRetries, "Job should have 1 max retries")
task = &DummyTask{result: "error", err: errors.New("Failure"), delay: 10 * time.Millisecond}
job, _ = NewJob(&JobOptions{
Task: task,
MaxRetries: 2,
})
go job.Run()
_, err = job.Future.Result()
assert.NotNil(t, err, "Job should return an error")
assert.Equal(t, "Failure", err.Error(), "Job should return the task's error")
assert.Equal(t, 2, job.retries, "Job should have 2 retries")
assert.Equal(t, 2, job.maxRetries, "Job should have 2 max retries")
}