/
NodeConcurrencyFilterTest.java
91 lines (67 loc) · 2.56 KB
/
NodeConcurrencyFilterTest.java
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
package org.jumpmind.symmetric.web;
import java.io.IOException;
import javax.servlet.ServletException;
import org.testng.Assert;
import org.testng.annotations.Test;
public class NodeConcurrencyFilterTest {
@Test(groups = "continuous", timeOut=60000)
public void testFilter() throws Exception {
NodeConcurrencyFilter filter = new NodeConcurrencyFilter();
filter.maxNumberOfConcurrentWorkers = 2;
filter.waitTimeBetweenRetriesInMs = 0;
MockWorker one = new MockWorker(filter,"push");
MockWorker two = new MockWorker(filter,"push");
MockWorker three = new MockWorker(filter,"push");
MockWorker other = new MockWorker(filter,"pull");
one.start();
Thread.sleep(500);
two.start();
Thread.sleep(500);
three.start();
Thread.sleep(500);
other.start();
Thread.sleep(500);
one.hold = false;
three.hold = false;
other.hold = false;
Thread.sleep(500);
Assert.assertEquals(one.success, true);
Assert.assertEquals(three.success, false);
Assert.assertEquals(other.success, true);
MockWorker four = new MockWorker(filter,"push");
four.start();
Thread.sleep(500);
two.hold = false;
four.hold = false;
Thread.sleep(500);
Assert.assertEquals(two.success, true);
Assert.assertEquals(four.success, true);
}
class MockWorker extends Thread {
String servletPath;
boolean hold = true;
NodeConcurrencyFilter filter;
boolean success;
MockWorker(NodeConcurrencyFilter filter, String path) {
this.setDaemon(true);
this.filter = filter;
this.servletPath = path;
}
public void run() {
try {
success = filter.doWork(servletPath, new NodeConcurrencyFilter.IWorker() {
public void work() throws ServletException, IOException {
while (hold) {
try {
Thread.sleep(50);
} catch (InterruptedException e) {
}
}
}
});
} catch (Exception ex) {
throw new RuntimeException();
}
}
}
}