diff options
author | Gordon Sim <gsim@apache.org> | 2006-11-17 11:03:22 +0000 |
---|---|---|
committer | Gordon Sim <gsim@apache.org> | 2006-11-17 11:03:22 +0000 |
commit | bf74286e6a5eba055fd8bf9410c325205b8595d5 (patch) | |
tree | 46fafd1086d95b543e5b8c4927ba28daa50e7da9 /cpp/src/qpid | |
parent | d965a29414762f0b3bbc840485f6327c3d523946 (diff) | |
download | qpid-python-bf74286e6a5eba055fd8bf9410c325205b8595d5.tar.gz |
Some fixes and tests for bugs uncovered during testing of persistence.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@476108 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid')
-rw-r--r-- | cpp/src/qpid/broker/Channel.cpp | 2 | ||||
-rw-r--r-- | cpp/src/qpid/broker/DeliveryRecord.cpp | 2 | ||||
-rw-r--r-- | cpp/src/qpid/broker/SessionHandlerImpl.cpp | 27 | ||||
-rw-r--r-- | cpp/src/qpid/broker/TxBuffer.cpp | 2 |
4 files changed, 22 insertions, 11 deletions
diff --git a/cpp/src/qpid/broker/Channel.cpp b/cpp/src/qpid/broker/Channel.cpp index f52d9ab8c7..f3624b4f3d 100644 --- a/cpp/src/qpid/broker/Channel.cpp +++ b/cpp/src/qpid/broker/Channel.cpp @@ -87,6 +87,8 @@ void Channel::close(){ for(consumer_iterator i = consumers.begin(); i != consumers.end(); i = consumers.begin() ){ cancel(i); } + //requeue: + recover(true); } void Channel::begin(){ diff --git a/cpp/src/qpid/broker/DeliveryRecord.cpp b/cpp/src/qpid/broker/DeliveryRecord.cpp index acfd2dccf6..a1efc17d19 100644 --- a/cpp/src/qpid/broker/DeliveryRecord.cpp +++ b/cpp/src/qpid/broker/DeliveryRecord.cpp @@ -64,7 +64,7 @@ void DeliveryRecord::redeliver(Channel* const channel) const{ void DeliveryRecord::requeue() const{ msg->redeliver(); - queue->deliver(msg); + queue->process(msg); } void DeliveryRecord::addTo(Prefetch* const prefetch) const{ diff --git a/cpp/src/qpid/broker/SessionHandlerImpl.cpp b/cpp/src/qpid/broker/SessionHandlerImpl.cpp index b1ac30d493..bbb5d22c8d 100644 --- a/cpp/src/qpid/broker/SessionHandlerImpl.cpp +++ b/cpp/src/qpid/broker/SessionHandlerImpl.cpp @@ -97,6 +97,9 @@ void SessionHandlerImpl::received(qpid::framing::AMQFrame* frame){ client.getChannel().close(channel, e.code, e.text, method->amqpClassId(), method->amqpMethodId()); }catch(ConnectionException& e){ client.getConnection().close(0, e.code, e.text, method->amqpClassId(), method->amqpMethodId()); + }catch(std::exception& e){ + string error(e.what()); + client.getConnection().close(0, 541/*internal error*/, error, method->amqpClassId(), method->amqpMethodId()); } break; @@ -132,16 +135,20 @@ void SessionHandlerImpl::idleIn(){ } void SessionHandlerImpl::closed(){ - for(channel_iterator i = channels.begin(); i != channels.end(); i = channels.begin()){ - Channel* c = i->second; - channels.erase(i); - c->close(); - delete c; - } - for(queue_iterator i = exclusiveQueues.begin(); i < exclusiveQueues.end(); i = exclusiveQueues.begin()){ - string name = (*i)->getName(); - queues->destroy(name); - exclusiveQueues.erase(i); + try { + for(channel_iterator i = channels.begin(); i != channels.end(); i = channels.begin()){ + Channel* c = i->second; + channels.erase(i); + c->close(); + delete c; + } + for(queue_iterator i = exclusiveQueues.begin(); i < exclusiveQueues.end(); i = exclusiveQueues.begin()){ + string name = (*i)->getName(); + queues->destroy(name); + exclusiveQueues.erase(i); + } + } catch(std::exception& e) { + std::cout << "Caught unhandled exception while closing session: " << e.what() << std::endl; } } diff --git a/cpp/src/qpid/broker/TxBuffer.cpp b/cpp/src/qpid/broker/TxBuffer.cpp index f344f89bf3..2bbe59b0e1 100644 --- a/cpp/src/qpid/broker/TxBuffer.cpp +++ b/cpp/src/qpid/broker/TxBuffer.cpp @@ -40,11 +40,13 @@ bool TxBuffer::prepare(TransactionalStore* const store) void TxBuffer::commit() { for_each(ops.begin(), ops.end(), mem_fun(&TxOp::commit)); + ops.clear(); } void TxBuffer::rollback() { for_each(ops.begin(), ops.end(), mem_fun(&TxOp::rollback)); + ops.clear(); } void TxBuffer::enlist(TxOp* const op) |