NO-JIRA Partially Revert "NO-JIRA Removing Wrong assertion"

I have changed ActiveMQActivation by mistake here at 385e11117b
This commit is contained in:
Clebert Suconic 2018-05-02 21:35:17 -04:00
parent 9765dadbcd
commit 2ddaa0aa86
1 changed files with 35 additions and 3 deletions

View File

@ -390,9 +390,25 @@ public class ActiveMQActivation {
} }
} }
Thread threadTearDown = new Thread("TearDown/ActiveMQActivation") {
@Override
public void run() {
for (ActiveMQMessageHandler handler : handlersCopy) { for (ActiveMQMessageHandler handler : handlersCopy) {
handler.teardown(); handler.teardown();
} }
}
};
// We will first start a new thread that will call tearDown on all the instances, trying to graciously shutdown everything.
// We will then use the call-timeout to determine a timeout.
// if that failed we will then close the connection factory, and interrupt the thread
threadTearDown.start();
try {
threadTearDown.join(timeout);
} catch (InterruptedException e) {
// nothing to be done on this context.. we will just keep going as we need to send an interrupt to threadTearDown and give up
}
if (factory != null) { if (factory != null) {
try { try {
@ -405,6 +421,20 @@ public class ActiveMQActivation {
factory = null; factory = null;
} }
if (threadTearDown.isAlive()) {
threadTearDown.interrupt();
try {
threadTearDown.join(5000);
} catch (InterruptedException e) {
// nothing to be done here.. we are going down anyways
}
if (threadTearDown.isAlive()) {
ActiveMQRALogger.LOGGER.threadCouldNotFinish(threadTearDown.toString());
}
}
nodes.clear(); nodes.clear();
lastReceived = false; lastReceived = false;
@ -518,7 +548,9 @@ public class ActiveMQActivation {
calculatedDestinationName = spec.getQueuePrefix() + calculatedDestinationName; calculatedDestinationName = spec.getQueuePrefix() + calculatedDestinationName;
} }
logger.debug("Unable to retrieve " + destinationName + " from JNDI. Creating a new " + destinationType.getName() + " named " + calculatedDestinationName + " to be used by the MDB."); logger.debug("Unable to retrieve " + destinationName +
" from JNDI. Creating a new " + destinationType.getName() +
" named " + calculatedDestinationName + " to be used by the MDB.");
// If there is no binding on naming, we will just create a new instance // If there is no binding on naming, we will just create a new instance
if (isTopic) { if (isTopic) {