mirror of https://github.com/apache/activemq.git
https://issues.apache.org/jira/browse/AMQ-3382 - statically included destination should be always forwarded
git-svn-id: https://svn.apache.org/repos/asf/activemq/trunk@1141124 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
92b4d68b6f
commit
4fcc1f7192
|
@ -954,7 +954,18 @@ public abstract class DemandForwardingBridgeSupport implements NetworkBridge, Br
|
|||
}
|
||||
}
|
||||
|
||||
ActiveMQDestination[] dests = excludedDestinations;
|
||||
ActiveMQDestination[] dests = staticallyIncludedDestinations;
|
||||
if (dests != null && dests.length > 0) {
|
||||
for (int i = 0; i < dests.length; i++) {
|
||||
ActiveMQDestination match = dests[i];
|
||||
DestinationFilter inclusionFilter = DestinationFilter.parseFilter(match);
|
||||
if (match != null && inclusionFilter.matches(destination) && dests[i].getDestinationType() == destination.getDestinationType()) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
dests = excludedDestinations;
|
||||
if (dests != null && dests.length > 0) {
|
||||
for (int i = 0; i < dests.length; i++) {
|
||||
ActiveMQDestination match = dests[i];
|
||||
|
|
|
@ -101,6 +101,12 @@ public class TestBrokerConnectionDuplexExcludedDestinations extends TestCase {
|
|||
hubProducer.setDisableMessageID(true);
|
||||
hubProducer.setDisableMessageTimestamp(true);
|
||||
|
||||
//create spoke producer
|
||||
MessageProducer spokeProducer = hubSession.createProducer(null);
|
||||
spokeProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
|
||||
spokeProducer.setDisableMessageID(true);
|
||||
spokeProducer.setDisableMessageTimestamp(true);
|
||||
|
||||
Queue excludedQueueHub = hubSession.createQueue("exclude.test.foo");
|
||||
TextMessage excludedMsgHub = hubSession.createTextMessage();
|
||||
excludedMsgHub.setText(excludedQueueHub.toString());
|
||||
|
@ -110,9 +116,15 @@ public class TestBrokerConnectionDuplexExcludedDestinations extends TestCase {
|
|||
TextMessage includedMsgHub = hubSession.createTextMessage();
|
||||
includedMsgHub.setText(includedQueueHub.toString());
|
||||
|
||||
Queue alwaysIncludedQueueHub = hubSession.createQueue("always.include.test.foo");
|
||||
|
||||
TextMessage alwaysIncludedMsgHub = hubSession.createTextMessage();
|
||||
alwaysIncludedMsgHub.setText(alwaysIncludedQueueHub.toString());
|
||||
|
||||
// Sending from Hub queue
|
||||
hubProducer.send(excludedQueueHub, excludedMsgHub);
|
||||
hubProducer.send(includedQueueHub, includedMsgHub);
|
||||
hubProducer.send(alwaysIncludedQueueHub, alwaysIncludedMsgHub);
|
||||
|
||||
|
||||
Queue excludedQueueSpoke = spokeSession.createQueue("exclude.test.foo");
|
||||
|
@ -123,6 +135,20 @@ public class TestBrokerConnectionDuplexExcludedDestinations extends TestCase {
|
|||
Queue includedQueueSpoke = spokeSession.createQueue("include.test.foo");
|
||||
MessageConsumer includedConsumerSpoke = spokeSession.createConsumer(includedQueueSpoke);
|
||||
|
||||
Thread.sleep(100);
|
||||
|
||||
Queue alwaysIncludedQueueSpoke = spokeSession.createQueue("always.include.test.foo");
|
||||
MessageConsumer alwaysIncludedConsumerSpoke = spokeSession.createConsumer(alwaysIncludedQueueHub);
|
||||
|
||||
Thread.sleep(100);
|
||||
TextMessage alwaysIncludedMsgSpoke = spokeSession.createTextMessage();
|
||||
alwaysIncludedMsgSpoke.setText(alwaysIncludedQueueSpoke.toString());
|
||||
spokeProducer.send(alwaysIncludedQueueSpoke, alwaysIncludedMsgSpoke);
|
||||
|
||||
|
||||
MessageConsumer alwaysIncludedConsumerHub = spokeSession.createConsumer(alwaysIncludedQueueHub);
|
||||
|
||||
|
||||
// Receiving from excluded Spoke queue
|
||||
Message msg = excludedConsumerSpoke.receive(200);
|
||||
assertNull(msg);
|
||||
|
@ -131,6 +157,10 @@ public class TestBrokerConnectionDuplexExcludedDestinations extends TestCase {
|
|||
msg = includedConsumerSpoke.receive(200);
|
||||
assertEquals(includedMsgHub, msg);
|
||||
|
||||
// Receiving from included Spoke queue
|
||||
msg = alwaysIncludedConsumerSpoke.receive(200);
|
||||
assertEquals(alwaysIncludedMsgHub, msg);
|
||||
|
||||
// we should be able to receive excluded queue message on Hub
|
||||
MessageConsumer excludedConsumerHub = hubSession.createConsumer(excludedQueueHub);
|
||||
msg = excludedConsumerHub.receive(200);;
|
||||
|
|
|
@ -40,8 +40,8 @@
|
|||
<topic physicalName="exclude.test.bar"/>
|
||||
</excludedDestinations>
|
||||
<staticallyIncludedDestinations>
|
||||
<queue physicalName="always.include.queue"/>
|
||||
<topic physicalName="always.include.topic"/>
|
||||
<queue physicalName="always.include.test.foo"/>
|
||||
<topic physicalName="always.include.test.bar"/>
|
||||
</staticallyIncludedDestinations>
|
||||
|
||||
</networkConnector>
|
||||
|
|
Loading…
Reference in New Issue