use of com.tvd12.ezyfox.util.EzyExceptionHandler in project ezyfox-server by youngmonkeys.
the class EzyPluginHandleExceptionImplTest method handleExceptionWithHandlers.
@Test
public void handleExceptionWithHandlers() {
// given
EzySimplePlugin plugin = new EzySimplePlugin();
EzySimplePluginSetting setting = new EzySimplePluginSetting();
String pluginName = RandomUtil.randomShortAlphabetString();
setting.setName(pluginName);
plugin.setSetting(setting);
EzyPluginHandleExceptionImpl sut = new EzyPluginHandleExceptionImpl(plugin);
Logger logger = mock(Logger.class);
FieldUtil.setFieldValue(sut, "logger", logger);
EzyExceptionHandler exceptionHandler = mock(EzyExceptionHandler.class);
plugin.getExceptionHandlers().addExceptionHandler(exceptionHandler);
// when
Exception exception = new IllegalArgumentException("one");
sut.handle(Thread.currentThread(), exception);
// then
verify(exceptionHandler, times(1)).handleException(Thread.currentThread(), exception);
verify(logger, times(0)).info("plugin: {} has no handler for exception:", pluginName, exception);
}
use of com.tvd12.ezyfox.util.EzyExceptionHandler in project ezyfox-server by youngmonkeys.
the class EzySimpleDataHandler method exceptionCaught.
public void exceptionCaught(Throwable cause) {
logger.debug("exception caught at session: {}", session, cause);
EzyExceptionHandler exceptionHandler = exceptionHandlers.get(cause.getClass());
if (exceptionHandler != null) {
exceptionHandler.handleException(Thread.currentThread(), cause);
}
}
use of com.tvd12.ezyfox.util.EzyExceptionHandler in project ezyfox-server by youngmonkeys.
the class EzyAddExceptionHandlerImpl method add.
@Override
public void add(EzyExceptionHandler handler) {
EzyExceptionHandlers handlers = fetcher.getExceptionHandlers();
handlers.addExceptionHandler(handler);
}
use of com.tvd12.ezyfox.util.EzyExceptionHandler in project ezyfox-server by youngmonkeys.
the class EzyAppHandleExceptionImplTest method handleExceptionWithHandlers.
@Test
public void handleExceptionWithHandlers() {
// given
EzySimpleApplication app = new EzySimpleApplication();
EzySimpleAppSetting setting = new EzySimpleAppSetting();
String appName = RandomUtil.randomShortAlphabetString();
setting.setName(appName);
app.setSetting(setting);
EzyAppHandleExceptionImpl sut = new EzyAppHandleExceptionImpl(app);
Logger logger = mock(Logger.class);
FieldUtil.setFieldValue(sut, "logger", logger);
EzyExceptionHandler exceptionHandler = mock(EzyExceptionHandler.class);
app.getExceptionHandlers().addExceptionHandler(exceptionHandler);
// when
Exception exception = new IllegalArgumentException("one");
sut.handle(Thread.currentThread(), exception);
// then
verify(exceptionHandler, times(1)).handleException(Thread.currentThread(), exception);
verify(logger, times(0)).info("app: {} has no handler for exception:", appName, exception);
}
use of com.tvd12.ezyfox.util.EzyExceptionHandler in project ezyfox-server by youngmonkeys.
the class EzyAppHandleExceptionImplTest method handleExceptionWithHandlersButException.
@Test
public void handleExceptionWithHandlersButException() {
// given
EzySimpleApplication app = new EzySimpleApplication();
EzySimpleAppSetting setting = new EzySimpleAppSetting();
String appName = RandomUtil.randomShortAlphabetString();
setting.setName(appName);
app.setSetting(setting);
EzyAppHandleExceptionImpl sut = new EzyAppHandleExceptionImpl(app);
Logger logger = mock(Logger.class);
FieldUtil.setFieldValue(sut, "logger", logger);
Exception exception = new IllegalArgumentException("one");
EzyExceptionHandler exceptionHandler = mock(EzyExceptionHandler.class);
RuntimeException ex = new RuntimeException("just test");
doThrow(ex).when(exceptionHandler).handleException(Thread.currentThread(), exception);
app.getExceptionHandlers().addExceptionHandler(exceptionHandler);
// when
sut.handle(Thread.currentThread(), exception);
// then
verify(exceptionHandler, times(1)).handleException(Thread.currentThread(), exception);
verify(logger, times(1)).warn("handle exception: {} on app: {} error", exceptionToSimpleString(exception), appName, ex);
}
Aggregations