forked from hybridgroup/gobot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
robot_work_test.go
102 lines (78 loc) · 2.17 KB
/
robot_work_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
package gobot
import (
"context"
"testing"
"time"
"github.com/gofrs/uuid"
"github.com/stretchr/testify/assert"
)
func TestRobotWork(t *testing.T) {
id, _ := uuid.NewV4()
rw := &RobotWork{
id: id,
kind: EveryWorkKind,
function: func() {},
}
duration := time.Second * 1
ctx, cancelFunc := context.WithCancel(context.Background())
rw.ctx = ctx
rw.cancelFunc = cancelFunc
rw.duration = duration
t.Run("ID()", func(t *testing.T) {
assert.Equal(t, rw.ID(), id)
})
t.Run("Ticker()", func(t *testing.T) {
t.Skip()
})
t.Run("Duration()", func(t *testing.T) {
assert.Equal(t, rw.duration, duration)
})
}
func TestRobotWorkRegistry(t *testing.T) {
robot := NewRobot("testbot")
rw := robot.Every(context.Background(), time.Millisecond*250, func() {
_ = 1 + 1
})
t.Run("Get retrieves", func(t *testing.T) {
assert.Equal(t, robot.workRegistry.Get(rw.id), rw)
})
t.Run("delete deletes", func(t *testing.T) {
robot.workRegistry.delete(rw.id)
postDeleteKeys := collectStringKeysFromWorkRegistry(robot.workRegistry)
assert.NotContains(t, postDeleteKeys, rw.id.String())
})
}
func TestRobotAutomationFunctions(t *testing.T) {
t.Run("Every with cancel", func(t *testing.T) {
robot := NewRobot("testbot")
counter := 0
rw := robot.Every(context.Background(), time.Millisecond*100, func() {
counter++
})
time.Sleep(time.Millisecond * 225)
rw.CallCancelFunc()
robot.WorkEveryWaitGroup.Wait()
assert.Equal(t, 2, counter)
postDeleteKeys := collectStringKeysFromWorkRegistry(robot.workRegistry)
assert.NotContains(t, postDeleteKeys, rw.id.String())
})
t.Run("After with cancel", func(t *testing.T) {
robot := NewRobot("testbot")
rw := robot.After(context.Background(), time.Millisecond*10, func() {
_ = 1 + 1 // perform mindless computation!
})
rw.CallCancelFunc()
robot.WorkAfterWaitGroup.Wait()
postDeleteKeys := collectStringKeysFromWorkRegistry(robot.workRegistry)
assert.NotContains(t, postDeleteKeys, rw.id.String())
})
}
func collectStringKeysFromWorkRegistry(rwr *RobotWorkRegistry) []string {
keys := make([]string, len(rwr.r))
var idx int
for key := range rwr.r {
keys[idx] = key
idx++
}
return keys
}