use of com.tvd12.ezyfoxserver.command.impl.EzyHandleExceptionImpl in project ezyfox-server by youngmonkeys.
the class EzyHandleExceptionImplTest method handleExceptionWithHandlers.
@Test
public void handleExceptionWithHandlers() {
// given
EzyExceptionHandlersFetcher fetcher = mock(EzyExceptionHandlersFetcher.class);
Exception exception = new IllegalArgumentException("one");
EzyExceptionHandlers handlers = mock(EzyExceptionHandlers.class);
when(fetcher.getExceptionHandlers()).thenReturn(handlers);
EzyHandleExceptionImpl sut = new EzyHandleExceptionImpl(fetcher);
Logger logger = mock(Logger.class);
FieldUtil.setFieldValue(sut, "logger", logger);
// when
sut.handle(Thread.currentThread(), exception);
// then
verify(handlers, times(1)).isEmpty();
verify(handlers, times(1)).handleException(Thread.currentThread(), exception);
verify(logger, times(0)).info("there is no handler for exception: ", exception);
}
use of com.tvd12.ezyfoxserver.command.impl.EzyHandleExceptionImpl in project ezyfox-server by youngmonkeys.
the class EzyHandleExceptionImplTest method handleExceptionWithHandlersButException.
@Test
public void handleExceptionWithHandlersButException() {
// given
EzyExceptionHandlersFetcher fetcher = mock(EzyExceptionHandlersFetcher.class);
Exception exception = new IllegalArgumentException("one");
EzyExceptionHandlers handlers = mock(EzyExceptionHandlers.class);
when(fetcher.getExceptionHandlers()).thenReturn(handlers);
EzyHandleExceptionImpl sut = new EzyHandleExceptionImpl(fetcher);
Logger logger = mock(Logger.class);
FieldUtil.setFieldValue(sut, "logger", logger);
RuntimeException ex = new RuntimeException("just test");
doThrow(ex).when(handlers).handleException(Thread.currentThread(), exception);
// when
sut.handle(Thread.currentThread(), exception);
// then
verify(handlers, times(1)).isEmpty();
verify(handlers, times(1)).handleException(Thread.currentThread(), exception);
verify(logger, times(1)).warn("handle exception: {} error", exceptionToSimpleString(exception), ex);
}
use of com.tvd12.ezyfoxserver.command.impl.EzyHandleExceptionImpl in project ezyfox-server by youngmonkeys.
the class EzyAbstractContext method init.
@Override
public final void init() {
this.commandSuppliers = defaultCommandSuppliers();
this.handleException = new EzyHandleExceptionImpl(component);
this.properties.put(EzyHandleException.class, handleException);
this.properties.put(EzyAddCommand.class, new EzyAddCommandImpl(this));
this.properties.put(EzyAddExceptionHandler.class, new EzyAddExceptionHandlerImpl(component));
this.doInit();
}
use of com.tvd12.ezyfoxserver.command.impl.EzyHandleExceptionImpl in project ezyfox-server by youngmonkeys.
the class EzyHandleExceptionImplTest method handleExceptionWithEmptyHandlers.
@Test
public void handleExceptionWithEmptyHandlers() {
// given
EzyExceptionHandlersFetcher fetcher = mock(EzyExceptionHandlersFetcher.class);
EzyExceptionHandlers handlers = mock(EzyExceptionHandlers.class);
when(handlers.isEmpty()).thenReturn(true);
when(fetcher.getExceptionHandlers()).thenReturn(handlers);
EzyHandleExceptionImpl sut = new EzyHandleExceptionImpl(fetcher);
Logger logger = mock(Logger.class);
FieldUtil.setFieldValue(sut, "logger", logger);
// when
Exception exception = new IllegalArgumentException("one");
sut.handle(Thread.currentThread(), exception);
// then
verify(handlers, times(1)).isEmpty();
verify(logger, times(1)).info("there is no handler for exception: ", exception);
}
Aggregations