-
Notifications
You must be signed in to change notification settings - Fork 0
/
microbatch_test.go
74 lines (65 loc) · 1.62 KB
/
microbatch_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
package microbatch
import (
"testing"
)
type DummyProcessor struct{}
// DummyProcessor implements required batchProcessor interface.
func (d *DummyProcessor) Process(j Job) (JobResult, error) {
return JobResult{
JobId: j.Id,
Result: true,
}, nil
}
// func TestMicroBatch_RunInBatch(t *testing.T) {
// tests := []struct {
// name string
// cfg Config
// jobs []Job
// }{
// {
// name: "Should run successfully run and exit even without any jobs submitted",
// cfg: Config{
// BatchSize: 10,
// Processor: &DummyProcessor{},
// Frequency: 2,
// },
// jobs: []Job{},
// },
// {
// name: "Should successfully return job result for submitted jobs",
// cfg: Config{
// BatchSize: 2,
// Processor: &DummyProcessor{},
// Frequency: 2,
// },
// jobs: []Job{{Task: 1, Id: 1}, {Task: 2, Id: 2}},
// },
// }
// for _, tt := range tests {
// t.Run(tt.name, func(t *testing.T) {
// m := NewMicroBatch(tt.cfg)
// for _, j := range tt.jobs {
// m.Submit(j)
// }
// m.Run(context.TODO())
// })
// }
// }
func TestMicrobatcher(t *testing.T) {
// t.Run("microbatcher should stay alive without any jobs in batch", func(t *testing.T) {
// m := NewMicroBatch(Config{
// BatchSize: 5,
// Processor: &DummyProcessor{},
// Frequency: time.Second * 5,
// })
// m.RunInBatch(context.Background())
// })
t.Run("microbatcher should process jobs specified in the batch size", func(t *testing.T) {
// m := NewMicroBatch(Config{
// BatchSize: 5,
// Processor: &DummyProcessor{},
// Frequency: time.Second * 5,
// })
// m.Run(context.Background())
})
}