-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathTestTaskManager.java
More file actions
177 lines (148 loc) · 4.02 KB
/
TestTaskManager.java
File metadata and controls
177 lines (148 loc) · 4.02 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
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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
package com.konloch;
import com.konloch.taskmanager.TaskManager;
import java.util.concurrent.atomic.AtomicInteger;
/**
* This is just one big test that validates each function inside the TaskManager
*
* @author Konloch
* @since 7/11/2022
*/
public class TestTaskManager
{
private static boolean noErrors = true;
private static boolean delayRanOnce = false;
private static boolean delaysRunningBehind = false;
private static boolean delaysRunningTooFast = false;
private static boolean ranDelay1 = false;
private static boolean ranDelay2 = false;
private static boolean ranLoop1 = false;
private static int loopCounter = 0;
public static void main(String[] args)
{
TaskManager manager = new TaskManager();
manager.start();
System.out.println("Testing the Task Manager, please wait...");
System.out.println();
//test error handling
manager.doOnce((task)->
{
throw new RuntimeException("Test Handling Errors");
});
long testDelays = System.currentTimeMillis();
//verify delays run only once
manager.doOnce((task)->
{
ranDelay1 = true;
if(delayRanOnce)
error("ERROR, ALREADY RAN ONCE");
else
delayRanOnce = true;
});
//verify delay executes once between a range of 30ms
manager.delay(100, (task)->
{
ranDelay2 = true;
if(System.currentTimeMillis()-testDelays <= 70)
{
error("DELAYS ARE NOT WORKING AS INTENDED - TOO SLOW");
delaysRunningBehind = true;
}
else if(System.currentTimeMillis()-testDelays >= 130)
{
error("DELAYS ARE NOT WORKING AS INTENDED - TOO FAST");
delaysRunningTooFast = true;
}
});
//test for loops
manager.loop(2, (task)->
{
if(!ranLoop1)
ranLoop1 = true;
if(loopCounter >= 2)
error("ERROR, ALREADY RAN ONCE");
else
loopCounter++;
});
//run test-2
manager.delay(1000, (task)-> test2(manager));
}
private static void test2(TaskManager manager)
{
//destroy the current manager
manager.destroy(()->
{
//restart the current manager
manager.start();
//run test-3
test3(manager);
});
}
private static void test3(TaskManager manager)
{
AtomicInteger runCount1 = new AtomicInteger();
AtomicInteger runCount2 = new AtomicInteger();
AtomicInteger runCount3 = new AtomicInteger();
//run some delay loop tests
manager.delayLoop(10, (task)->
{
int rc = runCount1.incrementAndGet();
if(rc == 5)
task.stop();
else if(rc > 5)
error("STOP FUNCTION IS NOT WORKING AS INTENDED (RC-1)");
});
//test running forever
manager.doForever((task)->
{
int rc = runCount2.incrementAndGet();
if(rc == 5)
task.stop();
else if(rc > 5)
error("STOP FUNCTION IS NOT WORKING AS INTENDED (RC-2)");
});
//test do while
manager.doWhile(()->{
return runCount3.incrementAndGet() < 5;
}, (task)->{
int rc = runCount3.get();
if(rc > 5)
error("DOWHILE FUNCTION IS NOT WORKING AS INTENDED (RC-3)");
});
//verify everything is running as expected
manager.delay(1000, (task)->
{
if(!noErrors)
return;
if(ranDelay1 && delayRanOnce && ranDelay2 && !delaysRunningBehind && !delaysRunningTooFast)
System.out.println(".delay PASSED ALL CHECKS");
else
System.err.println(".delay FAILED");
if(ranDelay1 && delayRanOnce)
System.out.println(".doOnce PASSED ALL CHECKS");
else
System.err.println(".doOnce FAILED");
if(runCount2.get() == 5)
System.out.println(".doForever PASSED ALL CHECKS");
else
System.err.println(".doForever FAILED");
if(runCount3.get() == 5)
System.out.println(".doWhile PASSED ALL CHECKS");
else
System.err.println(".doWhile FAILED");
if(ranLoop1 && loopCounter == 2)
System.out.println(".loop PASSED ALL CHECKS");
else
System.err.println(".loop FAILED");
if(runCount1.get() == 5)
System.out.println(".delayLoop PASSED ALL CHECKS");
else
System.err.println(".delayLoop FAILED");
manager.destroy();
});
}
private static void error(String reason)
{
noErrors = false;
System.err.println(reason);
}
}