/** * Copyright (c) 2000-present Liferay, Inc. All rights reserved. * * This library is free software; you can redistribute it and/or modify it under * the terms of the GNU Lesser General Public License as published by the Free * Software Foundation; either version 2.1 of the License, or (at your option) * any later version. * * This library is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more * details. */ package com.liferay.portal.kernel.nio.intraband; import com.liferay.portal.kernel.test.CaptureHandler; import com.liferay.portal.kernel.test.JDKLoggerTestUtil; import com.liferay.portal.kernel.test.rule.AggregateTestRule; import com.liferay.portal.kernel.test.rule.CodeCoverageAssertor; import com.liferay.portal.kernel.test.rule.NewEnv; import com.liferay.portal.test.rule.AdviseWith; import com.liferay.portal.test.rule.AspectJNewEnvTestRule; import com.liferay.registry.BasicRegistryImpl; import com.liferay.registry.RegistryUtil; import java.util.List; import java.util.logging.Level; import java.util.logging.LogRecord; import org.junit.Assert; import org.junit.Before; import org.junit.ClassRule; import org.junit.Rule; import org.junit.Test; /** * @author Shuyang Zhou */ @NewEnv(type = NewEnv.Type.CLASSLOADER) public class BaseAsyncDatagramReceiveHandlerTest { @ClassRule @Rule public static final AggregateTestRule aggregateTestRule = new AggregateTestRule( CodeCoverageAssertor.INSTANCE, AspectJNewEnvTestRule.INSTANCE); @Before public void setUp() { RegistryUtil.setRegistry(new BasicRegistryImpl()); } @AdviseWith(adviceClasses = {PortalExecutorManagerUtilAdvice.class}) @Test public void testErrorDispatch() { try (CaptureHandler captureHandler = JDKLoggerTestUtil.configureJDKLogger( BaseAsyncDatagramReceiveHandler.class.getName(), Level.SEVERE)) { List<LogRecord> logRecords = captureHandler.getLogRecords(); ErrorAsyncDatagramReceiveHandler errorAsyncDatagramReceiveHandler = new ErrorAsyncDatagramReceiveHandler(); errorAsyncDatagramReceiveHandler.receive(null, null); Assert.assertEquals(logRecords.toString(), 1, logRecords.size()); LogRecord logRecord = logRecords.get(0); Assert.assertEquals("Unable to dispatch", logRecord.getMessage()); Throwable throwable = logRecord.getThrown(); Assert.assertEquals(Exception.class, throwable.getClass()); } } @AdviseWith(adviceClasses = {PortalExecutorManagerUtilAdvice.class}) @Test public void testNormalDispatch() { DummyAsyncDatagramReceiveHandler dummyAsyncDatagramReceiveHandler = new DummyAsyncDatagramReceiveHandler(); dummyAsyncDatagramReceiveHandler.receive(null, null); Assert.assertTrue(dummyAsyncDatagramReceiveHandler._received); } private static class DummyAsyncDatagramReceiveHandler extends BaseAsyncDatagramReceiveHandler { @Override protected void doReceive( RegistrationReference registrationReference, Datagram datagram) { _received = true; } private boolean _received; } private static class ErrorAsyncDatagramReceiveHandler extends BaseAsyncDatagramReceiveHandler { @Override protected void doReceive( RegistrationReference registrationReference, Datagram datagram) throws Exception { throw new Exception(); } } }