This closes #150 memory leak fix
This commit is contained in:
commit
3df29ca7f3
|
@ -109,8 +109,10 @@ public final class BindingsImpl implements Bindings {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!bindings.contains(binding)) {
|
||||||
bindings.add(binding);
|
bindings.add(binding);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bindingsMap.put(binding.getID(), binding);
|
bindingsMap.put(binding.getID(), binding);
|
||||||
|
|
||||||
|
@ -141,7 +143,7 @@ public final class BindingsImpl implements Bindings {
|
||||||
bindingsMap.remove(binding.getID());
|
bindingsMap.remove(binding.getID());
|
||||||
|
|
||||||
if (isTrace) {
|
if (isTrace) {
|
||||||
ActiveMQServerLogger.LOGGER.trace("Removing binding " + binding + " into " + this + " bindingTable: " + debugBindings());
|
ActiveMQServerLogger.LOGGER.trace("Removing binding " + binding + " from " + this + " bindingTable: " + debugBindings());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -509,54 +511,51 @@ public final class BindingsImpl implements Bindings {
|
||||||
|
|
||||||
PrintWriter out = new PrintWriter(writer);
|
PrintWriter out = new PrintWriter(writer);
|
||||||
|
|
||||||
out.println("\n***************************************");
|
out.println("\n**************************************************");
|
||||||
|
|
||||||
out.println("routingNameBindingMap:");
|
out.println("routingNameBindingMap:");
|
||||||
if (routingNameBindingMap.isEmpty()) {
|
if (routingNameBindingMap.isEmpty()) {
|
||||||
out.println("EMPTY!");
|
out.println("\tEMPTY!");
|
||||||
}
|
}
|
||||||
for (Map.Entry<SimpleString, List<Binding>> entry : routingNameBindingMap.entrySet()) {
|
for (Map.Entry<SimpleString, List<Binding>> entry : routingNameBindingMap.entrySet()) {
|
||||||
out.print("key=" + entry.getKey() + ", value=" + entry.getValue());
|
out.println("\tkey=" + entry.getKey() + ", value(s):");
|
||||||
// for (Binding bind : entry.getValue())
|
for (Binding bind : entry.getValue()) {
|
||||||
// {
|
out.println("\t\t" + bind);
|
||||||
// out.print(bind + ",");
|
}
|
||||||
// }
|
|
||||||
out.println();
|
out.println();
|
||||||
}
|
}
|
||||||
|
|
||||||
out.println();
|
out.println("routingNamePositions:");
|
||||||
|
|
||||||
out.println("RoutingNamePositions:");
|
|
||||||
if (routingNamePositions.isEmpty()) {
|
if (routingNamePositions.isEmpty()) {
|
||||||
out.println("EMPTY!");
|
out.println("\tEMPTY!");
|
||||||
}
|
}
|
||||||
for (Map.Entry<SimpleString, Integer> entry : routingNamePositions.entrySet()) {
|
for (Map.Entry<SimpleString, Integer> entry : routingNamePositions.entrySet()) {
|
||||||
out.println("key=" + entry.getKey() + ", value=" + entry.getValue());
|
out.println("\tkey=" + entry.getKey() + ", value=" + entry.getValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
out.println();
|
out.println();
|
||||||
|
|
||||||
out.println("BindingsMap:");
|
out.println("bindingsMap:");
|
||||||
|
|
||||||
if (bindingsMap.isEmpty()) {
|
if (bindingsMap.isEmpty()) {
|
||||||
out.println("EMPTY!");
|
out.println("\tEMPTY!");
|
||||||
}
|
}
|
||||||
for (Map.Entry<Long, Binding> entry : bindingsMap.entrySet()) {
|
for (Map.Entry<Long, Binding> entry : bindingsMap.entrySet()) {
|
||||||
out.println("Key=" + entry.getKey() + ", value=" + entry.getValue());
|
out.println("\tkey=" + entry.getKey() + ", value=" + entry.getValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
out.println();
|
out.println();
|
||||||
|
|
||||||
out.println("ExclusiveBindings:");
|
out.println("exclusiveBindings:");
|
||||||
if (exclusiveBindings.isEmpty()) {
|
if (exclusiveBindings.isEmpty()) {
|
||||||
out.println("EMPTY!");
|
out.println("\tEMPTY!");
|
||||||
}
|
}
|
||||||
|
|
||||||
for (Binding binding : exclusiveBindings) {
|
for (Binding binding : exclusiveBindings) {
|
||||||
out.println(binding);
|
out.println("\t" + binding);
|
||||||
}
|
}
|
||||||
|
|
||||||
out.println("#####################################################");
|
out.println("####################################################");
|
||||||
|
|
||||||
return writer.toString();
|
return writer.toString();
|
||||||
}
|
}
|
||||||
|
@ -606,4 +605,7 @@ public final class BindingsImpl implements Bindings {
|
||||||
return pos;
|
return pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Map<SimpleString, List<Binding>> getRoutingNameBindingMap() {
|
||||||
|
return routingNameBindingMap;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,15 +22,22 @@ import javax.jms.MessageProducer;
|
||||||
import javax.jms.Session;
|
import javax.jms.Session;
|
||||||
import javax.jms.TextMessage;
|
import javax.jms.TextMessage;
|
||||||
import javax.jms.Topic;
|
import javax.jms.Topic;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
import org.apache.activemq.artemis.api.core.SimpleString;
|
import org.apache.activemq.artemis.api.core.SimpleString;
|
||||||
import org.apache.activemq.artemis.tests.util.JMSTestBase;
|
import org.apache.activemq.artemis.api.jms.ActiveMQJMSClient;
|
||||||
import org.apache.activemq.artemis.core.filter.impl.FilterImpl;
|
import org.apache.activemq.artemis.core.filter.impl.FilterImpl;
|
||||||
import org.apache.activemq.artemis.core.persistence.StorageManager;
|
import org.apache.activemq.artemis.core.persistence.StorageManager;
|
||||||
|
import org.apache.activemq.artemis.core.postoffice.Binding;
|
||||||
|
import org.apache.activemq.artemis.core.postoffice.Bindings;
|
||||||
|
import org.apache.activemq.artemis.core.postoffice.impl.BindingsImpl;
|
||||||
import org.apache.activemq.artemis.core.postoffice.impl.LocalQueueBinding;
|
import org.apache.activemq.artemis.core.postoffice.impl.LocalQueueBinding;
|
||||||
import org.apache.activemq.artemis.core.server.Queue;
|
import org.apache.activemq.artemis.core.server.Queue;
|
||||||
import org.apache.activemq.artemis.core.server.impl.ActiveMQServerImpl;
|
import org.apache.activemq.artemis.core.server.impl.ActiveMQServerImpl;
|
||||||
import org.apache.activemq.artemis.core.server.impl.QueueImpl;
|
import org.apache.activemq.artemis.core.server.impl.QueueImpl;
|
||||||
|
import org.apache.activemq.artemis.jms.client.ActiveMQTopic;
|
||||||
|
import org.apache.activemq.artemis.tests.util.JMSTestBase;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -97,4 +104,53 @@ public class TopicCleanupTest extends JMSTestBase {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testWildcardSubscriber() throws Exception {
|
||||||
|
ActiveMQTopic topic = (ActiveMQTopic) createTopic("topic.A");
|
||||||
|
Connection conn = cf.createConnection();
|
||||||
|
conn.start();
|
||||||
|
|
||||||
|
try {
|
||||||
|
Session consumerStarSession = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
|
||||||
|
MessageConsumer consumerStar = consumerStarSession.createConsumer(ActiveMQJMSClient.createTopic("topic.*"));
|
||||||
|
|
||||||
|
Session consumerASession = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
|
||||||
|
MessageConsumer consumerA = consumerASession.createConsumer(topic);
|
||||||
|
|
||||||
|
Session producerSession = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
|
||||||
|
MessageProducer producerA = producerSession.createProducer(topic);
|
||||||
|
TextMessage msg1 = producerSession.createTextMessage("text");
|
||||||
|
producerA.send(msg1);
|
||||||
|
|
||||||
|
consumerStar.close();
|
||||||
|
consumerA.close();
|
||||||
|
|
||||||
|
producerA.send(msg1);
|
||||||
|
|
||||||
|
conn.close();
|
||||||
|
|
||||||
|
boolean foundStrayRoutingBinding = false;
|
||||||
|
Bindings bindings = server.getPostOffice().getBindingsForAddress(new SimpleString(((ActiveMQTopic) topic).getAddress()));
|
||||||
|
Map<SimpleString, List<Binding>> routingNames = ((BindingsImpl) bindings).getRoutingNameBindingMap();
|
||||||
|
for (SimpleString key : routingNames.keySet()) {
|
||||||
|
if (!key.toString().equals(topic.getAddress())) {
|
||||||
|
foundStrayRoutingBinding = true;
|
||||||
|
assertEquals(0, ((LocalQueueBinding) routingNames.get(key).get(0)).getQueue().getMessageCount());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
assertFalse(foundStrayRoutingBinding);
|
||||||
|
}
|
||||||
|
finally {
|
||||||
|
jmsServer.stop();
|
||||||
|
|
||||||
|
jmsServer.start();
|
||||||
|
|
||||||
|
try {
|
||||||
|
conn.close();
|
||||||
|
}
|
||||||
|
catch (Throwable igonred) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue