mirror of https://github.com/apache/activemq.git
merge -c 918381 https://svn.apache.org/repos/asf/activemq/trunk - resolve https://issues.apache.org/activemq/browse/AMQ-2630 - added test and restricted imlementation
git-svn-id: https://svn.apache.org/repos/asf/activemq/branches/activemq-5.3@918388 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
9af5cfcdcc
commit
6ceab80bbe
|
@ -117,6 +117,17 @@ public abstract class ActiveMQDestination extends JNDIBaseStorable implements Da
|
||||||
if (dest instanceof ActiveMQDestination) {
|
if (dest instanceof ActiveMQDestination) {
|
||||||
return (ActiveMQDestination)dest;
|
return (ActiveMQDestination)dest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (dest instanceof Queue && dest instanceof Topic) {
|
||||||
|
String queueName = ((Queue) dest).getQueueName();
|
||||||
|
String topicName = ((Topic) dest).getTopicName();
|
||||||
|
if (queueName != null && topicName == null) {
|
||||||
|
return new ActiveMQQueue(queueName);
|
||||||
|
} else if (queueName == null && topicName != null) {
|
||||||
|
return new ActiveMQTopic(topicName);
|
||||||
|
}
|
||||||
|
throw new JMSException("Could no disambiguate on queue|Topic-name totransform pollymorphic destination into a ActiveMQ destination: " + dest);
|
||||||
|
}
|
||||||
if (dest instanceof TemporaryQueue) {
|
if (dest instanceof TemporaryQueue) {
|
||||||
return new ActiveMQTempQueue(((TemporaryQueue)dest).getQueueName());
|
return new ActiveMQTempQueue(((TemporaryQueue)dest).getQueueName());
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,6 +24,12 @@ import java.util.Map;
|
||||||
import java.util.SortedSet;
|
import java.util.SortedSet;
|
||||||
import java.util.TreeSet;
|
import java.util.TreeSet;
|
||||||
|
|
||||||
|
import javax.jms.JMSException;
|
||||||
|
import javax.jms.Queue;
|
||||||
|
import javax.jms.TemporaryQueue;
|
||||||
|
import javax.jms.TemporaryTopic;
|
||||||
|
import javax.jms.Topic;
|
||||||
|
|
||||||
import junit.framework.Test;
|
import junit.framework.Test;
|
||||||
|
|
||||||
public class ActiveMQDestinationTest extends DataStructureTestSupport {
|
public class ActiveMQDestinationTest extends DataStructureTestSupport {
|
||||||
|
@ -71,6 +77,46 @@ public class ActiveMQDestinationTest extends DataStructureTestSupport {
|
||||||
assertEquals("Sorted order", expected, actual);
|
assertEquals("Sorted order", expected, actual);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// https://issues.apache.org/activemq/browse/AMQ-2630
|
||||||
|
class CombyDest implements Queue, Topic, TemporaryQueue, TemporaryTopic {
|
||||||
|
|
||||||
|
private final String qName;
|
||||||
|
private final String topicName;
|
||||||
|
|
||||||
|
public CombyDest(String qName, String topicName) {
|
||||||
|
this.qName = qName;
|
||||||
|
this.topicName = topicName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void delete() throws JMSException {
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getTopicName() throws JMSException {
|
||||||
|
return topicName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getQueueName() throws JMSException {
|
||||||
|
return qName;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testTransformPollymorphic() throws Exception {
|
||||||
|
ActiveMQQueue queue = new ActiveMQQueue("TEST");
|
||||||
|
assertEquals(ActiveMQDestination.transform(queue), queue);
|
||||||
|
assertTrue("is a q", ActiveMQDestination.transform(new CombyDest(null, "Topic")) instanceof ActiveMQTopic);
|
||||||
|
assertTrue("is a q", ActiveMQDestination.transform(new CombyDest("Q", null)) instanceof ActiveMQQueue);
|
||||||
|
try {
|
||||||
|
ActiveMQDestination.transform(new CombyDest(null, null));
|
||||||
|
fail("expect ex as cannot disambiguate");
|
||||||
|
} catch (JMSException expected) {
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
ActiveMQDestination.transform(new CombyDest("Q", "T"));
|
||||||
|
fail("expect ex as cannot disambiguate");
|
||||||
|
} catch (JMSException expected) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static Test suite() {
|
public static Test suite() {
|
||||||
return suite(ActiveMQDestinationTest.class);
|
return suite(ActiveMQDestinationTest.class);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue