summaryrefslogtreecommitdiff
path: root/qpid/cpp/src/qpid/ha/Primary.cpp
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2013-02-07 19:26:02 +0000
committerAlan Conway <aconway@apache.org>2013-02-07 19:26:02 +0000
commit2f8518477686ce2382110d159349fe732db27a1a (patch)
tree79ad8c57475895ae7698ae76523383d294b7679a /qpid/cpp/src/qpid/ha/Primary.cpp
parent415e2d011a75374ad5757ff5b4d262228d143eb4 (diff)
downloadqpid-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.cpp9
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 "