Added verify function to avoid throwing so many runtime exceptions in the tests

This commit is contained in:
Mike Jensen 2014-03-11 09:20:34 -06:00
parent 68fca60d21
commit efb31dd09a
2 changed files with 58 additions and 130 deletions

View File

@ -18,12 +18,16 @@ public class CompleteionServiceTest {
takeTest(dumbExecutor); takeTest(dumbExecutor);
} }
private static void verify(boolean val) {
if (! val) {
throw new RuntimeException();
}
}
private static void pollNoResultTest(Executor executor) { private static void pollNoResultTest(Executor executor) {
ExecutorCompletionService<Object> ecs = new ExecutorCompletionService<Object>(executor); ExecutorCompletionService<Object> ecs = new ExecutorCompletionService<Object>(executor);
if (ecs.poll() != null) { verify(ecs.poll() == null);
throw new RuntimeException();
}
} }
private static void pollTimeoutNoResultTest(Executor executor) throws InterruptedException { private static void pollTimeoutNoResultTest(Executor executor) throws InterruptedException {
@ -31,12 +35,8 @@ public class CompleteionServiceTest {
ExecutorCompletionService<Object> ecs = new ExecutorCompletionService<Object>(executor); ExecutorCompletionService<Object> ecs = new ExecutorCompletionService<Object>(executor);
long startTime = System.currentTimeMillis(); long startTime = System.currentTimeMillis();
if (ecs.poll(delayTime, TimeUnit.MILLISECONDS) != null) { verify(ecs.poll(delayTime, TimeUnit.MILLISECONDS) == null);
throw new RuntimeException(); verify(System.currentTimeMillis() - startTime >= delayTime);
}
if (System.currentTimeMillis() - startTime < delayTime) {
throw new RuntimeException();
}
} }
private static void takeTest(Executor executor) throws InterruptedException, ExecutionException { private static void takeTest(Executor executor) throws InterruptedException, ExecutionException {
@ -49,8 +49,6 @@ public class CompleteionServiceTest {
} }
}); });
if (ecs.take().get() != result) { verify(ecs.take().get() == result);
throw new RuntimeException();
}
} }
} }

View File

@ -37,40 +37,34 @@ public class LinkedBlockingQueueTest {
toArrayTest(); toArrayTest();
} }
private static void verify(boolean val) {
if (! val) {
throw new RuntimeException();
}
}
private static void remainingCapacityTest() { private static void remainingCapacityTest() {
LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(2); LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(2);
if (lbq.remainingCapacity() != 2) { verify(lbq.remainingCapacity() == 2);
throw new RuntimeException();
}
lbq.add(new Object()); lbq.add(new Object());
if (lbq.remainingCapacity() != 1) { verify(lbq.remainingCapacity() == 1);
throw new RuntimeException();
}
} }
private static void sizeTest() { private static void sizeTest() {
LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(); LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>();
if (lbq.size() != 0) { verify(lbq.size() == 0);
throw new RuntimeException();
}
lbq.add(new Object()); lbq.add(new Object());
if (lbq.size() != 1) { verify(lbq.size() == 1);
throw new RuntimeException();
}
} }
private static void isEmptyTest() { private static void isEmptyTest() {
LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(); LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>();
if (! lbq.isEmpty()) { verify(lbq.isEmpty());
throw new RuntimeException();
}
lbq.add(new Object()); lbq.add(new Object());
if (lbq.isEmpty()) { verify(! lbq.isEmpty());
throw new RuntimeException();
}
} }
private static void addTest() { private static void addTest() {
@ -78,11 +72,8 @@ public class LinkedBlockingQueueTest {
Object testObject = new Object(); Object testObject = new Object();
lbq.add(testObject); lbq.add(testObject);
if (lbq.size() != 1) { verify(lbq.size() == 1);
throw new RuntimeException(); verify(lbq.peek() == testObject);
} else if (lbq.peek() != testObject) {
throw new RuntimeException();
}
} }
private static void addCapacityFail() { private static void addCapacityFail() {
@ -97,28 +88,18 @@ public class LinkedBlockingQueueTest {
// expected // expected
} }
if (lbq.size() != 1) { verify(lbq.size() == 1);
throw new RuntimeException(); verify(lbq.peek() == testObject);
} else if (lbq.peek() != testObject) {
throw new RuntimeException();
}
} }
private static void offerTest() { private static void offerTest() {
LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(1); LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(1);
Object testObject = new Object(); Object testObject = new Object();
if (! lbq.offer(testObject)) { verify(lbq.offer(testObject));
throw new RuntimeException(); verify(! lbq.offer(new Object()));
}
if (lbq.offer(new Object())) {
throw new RuntimeException();
}
if (lbq.size() != 1) { verify(lbq.size() == 1);
throw new RuntimeException(); verify(lbq.peek() == testObject);
} else if (lbq.peek() != testObject) {
throw new RuntimeException();
}
} }
private static void offerWithTimeoutTest() throws InterruptedException { private static void offerWithTimeoutTest() throws InterruptedException {
@ -139,18 +120,14 @@ public class LinkedBlockingQueueTest {
}).start(); }).start();
// should accept once thread starts // should accept once thread starts
if (! lbq.offer(new Object(), 10, TimeUnit.SECONDS)) { verify(lbq.offer(new Object(), 10, TimeUnit.SECONDS));
throw new RuntimeException();
}
} }
private static void offerTimeoutTest() throws InterruptedException { private static void offerTimeoutTest() throws InterruptedException {
LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(1); LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(1);
lbq.add(new Object()); lbq.add(new Object());
if (lbq.offer(new Object(), 10, TimeUnit.MILLISECONDS)) { verify(! lbq.offer(new Object(), 10, TimeUnit.MILLISECONDS));
throw new RuntimeException();
}
} }
private static void putTest() throws InterruptedException { private static void putTest() throws InterruptedException {
@ -158,11 +135,8 @@ public class LinkedBlockingQueueTest {
Object testObject = new Object(); Object testObject = new Object();
lbq.put(testObject); lbq.put(testObject);
if (lbq.size() != 1) { verify(lbq.size() == 1);
throw new RuntimeException(); verify(lbq.peek() == testObject);
} else if (lbq.peek() != testObject) {
throw new RuntimeException();
}
} }
private static void addAllTest() { private static void addAllTest() {
@ -173,13 +147,9 @@ public class LinkedBlockingQueueTest {
lbq.addAll(toAdd); lbq.addAll(toAdd);
if (lbq.size() != toAdd.size()) { verify(lbq.size() == toAdd.size());
throw new RuntimeException();
}
while (! lbq.isEmpty()) { while (! lbq.isEmpty()) {
if (lbq.remove() != toAdd.remove()) { verify(lbq.remove() == toAdd.remove());
throw new RuntimeException();
}
} }
} }
@ -202,9 +172,7 @@ public class LinkedBlockingQueueTest {
Object testObject = new Object(); Object testObject = new Object();
lbq.add(testObject); lbq.add(testObject);
if (lbq.element() != testObject) { verify(lbq.element() == testObject);
throw new RuntimeException();
}
} }
private static void elementFail() { private static void elementFail() {
@ -221,9 +189,7 @@ public class LinkedBlockingQueueTest {
private static void pollEmptyTest() { private static void pollEmptyTest() {
LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(); LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>();
if (lbq.poll() != null) { verify(lbq.poll() == null);
throw new RuntimeException();
}
} }
private static void pollTest() { private static void pollTest() {
@ -231,9 +197,7 @@ public class LinkedBlockingQueueTest {
Object testObject = new Object(); Object testObject = new Object();
lbq.add(testObject); lbq.add(testObject);
if (lbq.poll() != testObject) { verify(lbq.poll() == testObject);
throw new RuntimeException();
}
} }
private static void pollTimeoutTest() throws InterruptedException { private static void pollTimeoutTest() throws InterruptedException {
@ -253,9 +217,7 @@ public class LinkedBlockingQueueTest {
}).start(); }).start();
if (lbq.poll(DELAY_TILL_ACTION * 2, TimeUnit.MILLISECONDS) != testObject) { verify(lbq.poll(DELAY_TILL_ACTION * 2, TimeUnit.MILLISECONDS) == testObject);
throw new RuntimeException();
}
} }
private static void takeTest() throws InterruptedException { private static void takeTest() throws InterruptedException {
@ -275,9 +237,7 @@ public class LinkedBlockingQueueTest {
}).start(); }).start();
if (lbq.take() != testObject) { verify(lbq.take() == testObject);
throw new RuntimeException();
}
} }
private static void removeEmptyTest() { private static void removeEmptyTest() {
@ -296,9 +256,7 @@ public class LinkedBlockingQueueTest {
Object testObject = new Object(); Object testObject = new Object();
lbq.add(testObject); lbq.add(testObject);
if (lbq.remove() != testObject) { verify(lbq.remove() == testObject);
throw new RuntimeException();
}
} }
private static void drainToTest() { private static void drainToTest() {
@ -309,11 +267,8 @@ public class LinkedBlockingQueueTest {
} }
LinkedList<Object> drainToResult = new LinkedList<Object>(); LinkedList<Object> drainToResult = new LinkedList<Object>();
if (lbq.drainTo(drainToResult) != objQty) { verify(lbq.drainTo(drainToResult) == objQty);
throw new RuntimeException(); verify(drainToResult.size() == objQty);
} else if (drainToResult.size() != objQty) {
throw new RuntimeException();
}
} }
private static void drainToLimitTest() { private static void drainToLimitTest() {
@ -325,27 +280,19 @@ public class LinkedBlockingQueueTest {
} }
LinkedList<Object> drainToResult = new LinkedList<Object>(); LinkedList<Object> drainToResult = new LinkedList<Object>();
if (lbq.drainTo(drainToResult, limit) != limit) { verify(lbq.drainTo(drainToResult, limit) == limit);
throw new RuntimeException(); verify(drainToResult.size() == limit);
} else if (drainToResult.size() != limit) { verify(lbq.size() == objQty - limit);
throw new RuntimeException();
} else if (lbq.size() != objQty - limit) {
throw new RuntimeException();
}
} }
private static void containsTest() { private static void containsTest() {
LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(); LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>();
Object testObject = new Object(); Object testObject = new Object();
if (lbq.contains(testObject)) { verify(! lbq.contains(testObject));
throw new RuntimeException();
}
lbq.add(testObject); lbq.add(testObject);
if (! lbq.contains(testObject)) { verify(lbq.contains(testObject));
throw new RuntimeException();
}
} }
private static void containsAllTest() { private static void containsAllTest() {
@ -357,28 +304,20 @@ public class LinkedBlockingQueueTest {
testList.add(testObject); testList.add(testObject);
testList.add(new Object()); testList.add(new Object());
if (lbq.containsAll(testList)) { verify(! lbq.containsAll(testList));
throw new RuntimeException();
}
lbq.addAll(testList); lbq.addAll(testList);
if (! lbq.containsAll(testList)) { verify(lbq.containsAll(testList));
throw new RuntimeException();
}
} }
private static void removeObjectTest() { private static void removeObjectTest() {
LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>(); LinkedBlockingQueue<Object> lbq = new LinkedBlockingQueue<Object>();
Object testObject = new Object(); Object testObject = new Object();
if (lbq.remove(testObject)) { verify(! lbq.remove(testObject));
throw new RuntimeException();
}
lbq.add(testObject); lbq.add(testObject);
if (! lbq.remove(testObject)) { verify(lbq.remove(testObject));
throw new RuntimeException();
}
} }
private static void removeAllTest() { private static void removeAllTest() {
@ -390,14 +329,10 @@ public class LinkedBlockingQueueTest {
testList.add(testObject); testList.add(testObject);
testList.add(new Object()); testList.add(new Object());
if (! lbq.removeAll(testList)) { verify(lbq.removeAll(testList));
throw new RuntimeException();
}
lbq.addAll(testList); lbq.addAll(testList);
if (! lbq.removeAll(testList)) { verify(lbq.removeAll(testList));
throw new RuntimeException();
}
} }
private static void clearTest() { private static void clearTest() {
@ -406,9 +341,7 @@ public class LinkedBlockingQueueTest {
lbq.clear(); lbq.clear();
if (! lbq.isEmpty()) { verify(lbq.isEmpty());
throw new RuntimeException();
}
} }
private static void toArrayTest() { private static void toArrayTest() {
@ -422,10 +355,7 @@ public class LinkedBlockingQueueTest {
lbq.add(testObject); lbq.add(testObject);
Object[] result = lbq.toArray(); Object[] result = lbq.toArray();
if (result.length != 1) { verify(result.length == 1);
throw new RuntimeException(); verify(result[0] == testObject);
} else if (result[0] != testObject) {
throw new RuntimeException();
}
} }
} }