summaryrefslogtreecommitdiff
path: root/qpid/cpp/src
diff options
context:
space:
mode:
Diffstat (limited to 'qpid/cpp/src')
-rw-r--r--qpid/cpp/src/qpid/broker/Queue.cpp2
-rwxr-xr-xqpid/cpp/src/tests/acl.py3
2 files changed, 3 insertions, 2 deletions
diff --git a/qpid/cpp/src/qpid/broker/Queue.cpp b/qpid/cpp/src/qpid/broker/Queue.cpp
index 19b18e1b0e..a805e110ad 100644
--- a/qpid/cpp/src/qpid/broker/Queue.cpp
+++ b/qpid/cpp/src/qpid/broker/Queue.cpp
@@ -1323,7 +1323,7 @@ bool Queue::setExclusiveOwner(const OwnershipToken* const o)
autoDeleteTask->cancel();
}
Mutex::ScopedLock locker(messageLock);
- if (owner) {
+ if (owner || users.hasConsumers()) {
return false;
} else {
owner = o;
diff --git a/qpid/cpp/src/tests/acl.py b/qpid/cpp/src/tests/acl.py
index fe8254a6fa..66705e6d24 100755
--- a/qpid/cpp/src/tests/acl.py
+++ b/qpid/cpp/src/tests/acl.py
@@ -1570,7 +1570,8 @@ class ACLTests(TestBase010):
session = self.get_session('bob','bob')
try:
- session.message_subscribe(queue='q3', destination='myq1')
+ session.message_subscribe(queue='q3', destination='myq3')
+ session.message_cancel(destination='myq3')
except qpid.session.SessionException, e:
if (403 == e.args[0].error_code):
self.fail("ACL should allow subscription for q3");