summaryrefslogtreecommitdiff
path: root/qpid/java
diff options
context:
space:
mode:
authorRobert Gemmell <robbie@apache.org>2010-09-18 21:19:48 +0000
committerRobert Gemmell <robbie@apache.org>2010-09-18 21:19:48 +0000
commitd5a744ea500a3d043eebab637c283ee3fbf7c5db (patch)
treec116cf3300433948ea43e7c3c31fed3d9f9973ab /qpid/java
parentd737e450bfcbd0f85db0117f4110a5f42ec85a28 (diff)
downloadqpid-python-d5a744ea500a3d043eebab637c283ee3fbf7c5db.tar.gz
QPID-2869: prevent entering the source queue as destination
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@998548 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/java')
-rw-r--r--qpid/java/broker/src/main/java/org/apache/qpid/server/queue/SimpleAMQQueue.java8
1 files changed, 8 insertions, 0 deletions
diff --git a/qpid/java/broker/src/main/java/org/apache/qpid/server/queue/SimpleAMQQueue.java b/qpid/java/broker/src/main/java/org/apache/qpid/server/queue/SimpleAMQQueue.java
index 6fece81e88..ec6fb1f8de 100644
--- a/qpid/java/broker/src/main/java/org/apache/qpid/server/queue/SimpleAMQQueue.java
+++ b/qpid/java/broker/src/main/java/org/apache/qpid/server/queue/SimpleAMQQueue.java
@@ -1114,6 +1114,10 @@ public class SimpleAMQQueue implements AMQQueue, Subscription.StateListener
{
throw new IllegalArgumentException("Queue '" + queueName + "' is not registered with the virtualhost.");
}
+ else if (toQueue == this)
+ {
+ throw new IllegalArgumentException("The destination queue cant be the same as the source queue");
+ }
List<QueueEntry> entries = getMessagesOnTheQueue(new QueueEntryFilter()
{
@@ -1188,6 +1192,10 @@ public class SimpleAMQQueue implements AMQQueue, Subscription.StateListener
{
throw new IllegalArgumentException("Queue '" + queueName + "' is not registered with the virtualhost.");
}
+ else if (toQueue == this)
+ {
+ throw new IllegalArgumentException("The destination queue cant be the same as the source queue");
+ }
List<QueueEntry> entries = getMessagesOnTheQueue(new QueueEntryFilter()
{