Added proper tests for half-sync-half-async
This commit is contained in:
parent
ca14e8ddad
commit
dbca06a9e7
@ -14,5 +14,10 @@
|
|||||||
<artifactId>junit</artifactId>
|
<artifactId>junit</artifactId>
|
||||||
<scope>test</scope>
|
<scope>test</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.mockito</groupId>
|
||||||
|
<artifactId>mockito-core</artifactId>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</project>
|
</project>
|
||||||
|
@ -50,6 +50,7 @@ public class AsynchronousService {
|
|||||||
task.onPreCall();
|
task.onPreCall();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
task.onError(e);
|
task.onError(e);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
service.submit(new FutureTask<T>(task) {
|
service.submit(new FutureTask<T>(task) {
|
||||||
|
@ -0,0 +1,79 @@
|
|||||||
|
package com.iluwatar.halfsynchalfasync;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.mockito.InOrder;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.concurrent.LinkedBlockingQueue;
|
||||||
|
|
||||||
|
import static org.mockito.Matchers.eq;
|
||||||
|
import static org.mockito.Mockito.doThrow;
|
||||||
|
import static org.mockito.Mockito.inOrder;
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.timeout;
|
||||||
|
import static org.mockito.Mockito.times;
|
||||||
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.verifyNoMoreInteractions;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Date: 12/12/15 - 11:15 PM
|
||||||
|
*
|
||||||
|
* @author Jeroen Meulemeester
|
||||||
|
*/
|
||||||
|
public class AsynchronousServiceTest {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testPerfectExecution() throws Exception {
|
||||||
|
final AsynchronousService service = new AsynchronousService(new LinkedBlockingQueue<>());
|
||||||
|
final AsyncTask<Object> task = mock(AsyncTask.class);
|
||||||
|
final Object result = new Object();
|
||||||
|
when(task.call()).thenReturn(result);
|
||||||
|
service.execute(task);
|
||||||
|
|
||||||
|
verify(task, timeout(2000)).onPostCall(eq(result));
|
||||||
|
|
||||||
|
final InOrder inOrder = inOrder(task);
|
||||||
|
inOrder.verify(task, times(1)).onPreCall();
|
||||||
|
inOrder.verify(task, times(1)).call();
|
||||||
|
inOrder.verify(task, times(1)).onPostCall(eq(result));
|
||||||
|
|
||||||
|
verifyNoMoreInteractions(task);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testCallException() throws Exception {
|
||||||
|
final AsynchronousService service = new AsynchronousService(new LinkedBlockingQueue<>());
|
||||||
|
final AsyncTask<Object> task = mock(AsyncTask.class);
|
||||||
|
final IOException exception = new IOException();
|
||||||
|
when(task.call()).thenThrow(exception);
|
||||||
|
service.execute(task);
|
||||||
|
|
||||||
|
verify(task, timeout(2000)).onError(eq(exception));
|
||||||
|
|
||||||
|
final InOrder inOrder = inOrder(task);
|
||||||
|
inOrder.verify(task, times(1)).onPreCall();
|
||||||
|
inOrder.verify(task, times(1)).call();
|
||||||
|
inOrder.verify(task, times(1)).onError(exception);
|
||||||
|
|
||||||
|
verifyNoMoreInteractions(task);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testPreCallException() throws Exception {
|
||||||
|
final AsynchronousService service = new AsynchronousService(new LinkedBlockingQueue<>());
|
||||||
|
final AsyncTask<Object> task = mock(AsyncTask.class);
|
||||||
|
final IllegalStateException exception = new IllegalStateException();
|
||||||
|
doThrow(exception).when(task).onPreCall();
|
||||||
|
service.execute(task);
|
||||||
|
|
||||||
|
verify(task, timeout(2000)).onError(eq(exception));
|
||||||
|
|
||||||
|
final InOrder inOrder = inOrder(task);
|
||||||
|
inOrder.verify(task, times(1)).onPreCall();
|
||||||
|
inOrder.verify(task, times(1)).onError(exception);
|
||||||
|
|
||||||
|
verifyNoMoreInteractions(task);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user