From 640a6ece45a60b389994e6e114501e0d0cd87b7f Mon Sep 17 00:00:00 2001 From: jbjohnso Date: Mon, 21 Apr 2014 17:01:25 -0400 Subject: [PATCH] Correct configmanager registration failures with no tenants --- confluent/config/configmanager.py | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/confluent/config/configmanager.py b/confluent/config/configmanager.py index 78d3ef15..7fddaff9 100644 --- a/confluent/config/configmanager.py +++ b/confluent/config/configmanager.py @@ -380,7 +380,7 @@ def _addchange(changeset, node, attrname): def hook_new_configmanagers(callback): - '''Register callback for new tenants + """Register callback for new tenants From the point when this function is called until the end, callback may be invoked to indicate a new tenant and @@ -389,11 +389,14 @@ def hook_new_configmanagers(callback): :param callback: Function to call for each possible config manager :returns: identifier that can be used to cancel this registration - ''' + """ #TODO(jbjohnso): actually live up to the promise of ongoing callbacks callback(ConfigManager(None)) - for tenant in _cfgstore['tenant'].iterkeys(): - callback(ConfigManager(tenant)) + try: + for tenant in _cfgstore['tenant'].iterkeys(): + callback(ConfigManager(tenant)) + except KeyError: + pass class ConfigManager(object):