ARTEMIS-2190 core JMS client leaks temp dest names

This commit is contained in:
Justin Bertram 2018-12-04 11:01:30 -06:00 committed by Francesco Nigro
parent e41a24af78
commit 4ab7923a84
2 changed files with 48 additions and 0 deletions

View File

@ -548,6 +548,7 @@ public class ActiveMQConnection extends ActiveMQConnectionForContextImpl impleme
public void removeTemporaryQueue(final SimpleString queueAddress) { public void removeTemporaryQueue(final SimpleString queueAddress) {
tempQueues.remove(queueAddress); tempQueues.remove(queueAddress);
knownDestinations.remove(queueAddress);
} }
public void addKnownDestination(final SimpleString address) { public void addKnownDestination(final SimpleString address) {

View File

@ -28,6 +28,8 @@ import javax.jms.TextMessage;
import javax.naming.NamingException; import javax.naming.NamingException;
import org.apache.activemq.artemis.core.settings.impl.AddressSettings; import org.apache.activemq.artemis.core.settings.impl.AddressSettings;
import org.apache.activemq.artemis.api.core.SimpleString;
import org.apache.activemq.artemis.jms.client.ActiveMQConnection;
import org.apache.activemq.artemis.jms.tests.util.ProxyAssertSupport; import org.apache.activemq.artemis.jms.tests.util.ProxyAssertSupport;
import org.junit.Test; import org.junit.Test;
@ -127,6 +129,51 @@ public class TemporaryDestinationTest extends JMSTestCase {
} }
} }
@Test
public void testTemporaryQueueLeak() throws Exception {
ActiveMQConnection conn = null;
try {
conn = (ActiveMQConnection) createConnection();
Session producerSession = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
Session consumerSession = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
TemporaryQueue tempQueue = producerSession.createTemporaryQueue();
MessageProducer producer = producerSession.createProducer(tempQueue);
MessageConsumer consumer = consumerSession.createConsumer(tempQueue);
conn.start();
final String messageText = "This is a message";
Message m = producerSession.createTextMessage(messageText);
producer.send(m);
TextMessage m2 = (TextMessage) consumer.receive(2000);
ProxyAssertSupport.assertNotNull(m2);
ProxyAssertSupport.assertEquals(messageText, m2.getText());
consumer.close();
tempQueue.delete();
ProxyAssertSupport.assertFalse(conn.containsKnownDestination(SimpleString.toSimpleString(tempQueue.getQueueName())));
ProxyAssertSupport.assertFalse(conn.containsTemporaryQueue(SimpleString.toSimpleString(tempQueue.getQueueName())));
} finally {
if (conn != null) {
conn.close();
}
}
}
/** /**
* http://jira.jboss.com/jira/browse/JBMESSAGING-93 * http://jira.jboss.com/jira/browse/JBMESSAGING-93
*/ */