diff options
author | Alan Conway <aconway@apache.org> | 2013-02-07 19:26:02 +0000 |
---|---|---|
committer | Alan Conway <aconway@apache.org> | 2013-02-07 19:26:02 +0000 |
commit | 2f8518477686ce2382110d159349fe732db27a1a (patch) | |
tree | 79ad8c57475895ae7698ae76523383d294b7679a /qpid/cpp/src/qpid/ha/Primary.cpp | |
parent | 415e2d011a75374ad5757ff5b4d262228d143eb4 (diff) | |
download | qpid-python-2f8518477686ce2382110d159349fe732db27a1a.tar.gz |
QPID-4555: HA Check for backup ready when new backup joins.
This test was missing so if there were no backed-up queues the backup would
never be marked ready. It was workig because of a separte bug:
auto-delete/exclusive queues were being replicated incorrectly so there were
always replicated queues (temp queues created by qpid-ha)
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1443677 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp/src/qpid/ha/Primary.cpp')
-rw-r--r-- | qpid/cpp/src/qpid/ha/Primary.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/qpid/cpp/src/qpid/ha/Primary.cpp b/qpid/cpp/src/qpid/ha/Primary.cpp index 12535399e3..67108fa5f9 100644 --- a/qpid/cpp/src/qpid/ha/Primary.cpp +++ b/qpid/cpp/src/qpid/ha/Primary.cpp @@ -245,14 +245,17 @@ void Primary::opened(broker::Connection& connection) { backup->setCatchupQueues(haBroker.getBroker().getQueues(), false); } backups[info.getSystemId()] = backup; + i = backups.find(info.getSystemId()); } else { QPID_LOG(info, logPrefix << "Known backup connected: " << info); i->second->setConnection(&connection); - checkReady(i, l); } - if (info.getStatus() == JOINING) info.setStatus(CATCHUP); - membership.add(info); + if (info.getStatus() == JOINING) { + info.setStatus(CATCHUP); + membership.add(info); + } + if (i != backups.end()) checkReady(i, l); } else QPID_LOG(debug, logPrefix << "Accepted client connection " |